You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
606 lines
23 KiB
606 lines
23 KiB
# 设置输出编码为 UTF-8
|
|
$OutputEncoding = [System.Text.Encoding]::UTF8
|
|
[Console]::OutputEncoding = [System.Text.Encoding]::UTF8
|
|
|
|
# 颜色定义
|
|
$RED = "`e[31m"
|
|
$GREEN = "`e[32m"
|
|
$YELLOW = "`e[33m"
|
|
$BLUE = "`e[34m"
|
|
$NC = "`e[0m"
|
|
|
|
# 配置文件路径
|
|
$STORAGE_FILE = "$env:APPDATA\Cursor\User\globalStorage\storage.json"
|
|
$BACKUP_DIR = "$env:APPDATA\Cursor\User\globalStorage\backups"
|
|
|
|
# 新增 Cursor 初始化函数
|
|
function Cursor-初始化 {
|
|
Write-Host "$GREEN[信息]$NC 正在执行 Cursor 初始化清理..."
|
|
$BASE_PATH = "$env:APPDATA\Cursor\User"
|
|
|
|
$filesToDelete = @(
|
|
(Join-Path -Path $BASE_PATH -ChildPath "globalStorage\\state.vscdb"),
|
|
(Join-Path -Path $BASE_PATH -ChildPath "globalStorage\\state.vscdb.backup")
|
|
)
|
|
|
|
$folderToCleanContents = Join-Path -Path $BASE_PATH -ChildPath "History"
|
|
$folderToDeleteCompletely = Join-Path -Path $BASE_PATH -ChildPath "workspaceStorage"
|
|
|
|
Write-Host "$BLUE[调试]$NC 基础路径: $BASE_PATH"
|
|
|
|
# 删除指定文件
|
|
foreach ($file in $filesToDelete) {
|
|
Write-Host "$BLUE[调试]$NC 检查文件: $file"
|
|
if (Test-Path $file) {
|
|
try {
|
|
Remove-Item -Path $file -Force -ErrorAction Stop
|
|
Write-Host "$GREEN[成功]$NC 已删除文件: $file"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 删除文件 $file 失败: $($_.Exception.Message)"
|
|
}
|
|
} else {
|
|
Write-Host "$YELLOW[警告]$NC 文件不存在,跳过删除: $file"
|
|
}
|
|
}
|
|
|
|
# 清空指定文件夹内容
|
|
Write-Host "$BLUE[调试]$NC 检查待清空文件夹: $folderToCleanContents"
|
|
if (Test-Path $folderToCleanContents) {
|
|
try {
|
|
# 获取子项进行删除,以避免删除 History 文件夹本身
|
|
Get-ChildItem -Path $folderToCleanContents -Recurse | Remove-Item -Recurse -Force -ErrorAction Stop
|
|
Write-Host "$GREEN[成功]$NC 已清空文件夹内容: $folderToCleanContents"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 清空文件夹 $folderToCleanContents 内容失败: $($_.Exception.Message)"
|
|
}
|
|
} else {
|
|
Write-Host "$YELLOW[警告]$NC 文件夹不存在,跳过清空: $folderToCleanContents"
|
|
}
|
|
|
|
# 删除指定文件夹及其内容
|
|
Write-Host "$BLUE[调试]$NC 检查待删除文件夹: $folderToDeleteCompletely"
|
|
if (Test-Path $folderToDeleteCompletely) {
|
|
try {
|
|
Remove-Item -Path $folderToDeleteCompletely -Recurse -Force -ErrorAction Stop
|
|
Write-Host "$GREEN[成功]$NC 已删除文件夹: $folderToDeleteCompletely"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 删除文件夹 $folderToDeleteCompletely 失败: $($_.Exception.Message)"
|
|
}
|
|
} else {
|
|
Write-Host "$YELLOW[警告]$NC 文件夹不存在,跳过删除: $folderToDeleteCompletely"
|
|
}
|
|
|
|
Write-Host "$GREEN[信息]$NC Cursor 初始化清理完成。"
|
|
Write-Host "" # 添加空行以改善输出格式
|
|
}
|
|
|
|
# 检查管理员权限
|
|
function Test-Administrator {
|
|
$user = [Security.Principal.WindowsIdentity]::GetCurrent()
|
|
$principal = New-Object Security.Principal.WindowsPrincipal($user)
|
|
return $principal.IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)
|
|
}
|
|
|
|
if (-not (Test-Administrator)) {
|
|
Write-Host "$RED[错误]$NC 请以管理员身份运行此脚本"
|
|
Write-Host "请右键点击脚本,选择'以管理员身份运行'"
|
|
Read-Host "按回车键退出"
|
|
exit 1
|
|
}
|
|
|
|
# 显示 Logo
|
|
Clear-Host
|
|
Write-Host @"
|
|
|
|
██████╗██╗ ██╗██████╗ ███████╗ ██████╗ ██████╗
|
|
██╔════╝██║ ██║██╔══██╗██╔════╝██╔═══██╗██╔══██╗
|
|
██║ ██║ ██║██████╔╝███████╗██║ ██║██████╔╝
|
|
██║ ██║ ██║██╔══██╗╚════██║██║ ██║██╔══██╗
|
|
╚██████╗╚██████╔╝██║ ██║███████║╚██████╔╝██║ ██║
|
|
╚═════╝ ╚═════╝ ╚═╝ ╚═╝╚══════╝ ╚═════╝ ╚═╝ ╚═╝
|
|
|
|
"@
|
|
Write-Host "$BLUE================================$NC"
|
|
Write-Host "$GREEN Cursor 设备ID 修改工具 $NC"
|
|
Write-Host "$YELLOW 关注公众号【煎饼果子卷AI】 $NC"
|
|
Write-Host "$YELLOW 一起交流更多Cursor技巧和AI知识(脚本免费、关注公众号加群有更多技巧和大佬) $NC"
|
|
Write-Host "$YELLOW [重要提示] 本工具免费,如果对您有帮助,请关注公众号【煎饼果子卷AI】 $NC"
|
|
Write-Host "$BLUE================================$NC"
|
|
Write-Host ""
|
|
|
|
# 获取并显示 Cursor 版本
|
|
function Get-CursorVersion {
|
|
try {
|
|
# 主要检测路径
|
|
$packagePath = "$env:LOCALAPPDATA\\Programs\\cursor\\resources\\app\\package.json"
|
|
|
|
if (Test-Path $packagePath) {
|
|
$packageJson = Get-Content $packagePath -Raw | ConvertFrom-Json
|
|
if ($packageJson.version) {
|
|
Write-Host "$GREEN[信息]$NC 当前安装的 Cursor 版本: v$($packageJson.version)"
|
|
return $packageJson.version
|
|
}
|
|
}
|
|
|
|
# 备用路径检测
|
|
$altPath = "$env:LOCALAPPDATA\\cursor\\resources\\app\\package.json"
|
|
if (Test-Path $altPath) {
|
|
$packageJson = Get-Content $altPath -Raw | ConvertFrom-Json
|
|
if ($packageJson.version) {
|
|
Write-Host "$GREEN[信息]$NC 当前安装的 Cursor 版本: v$($packageJson.version)"
|
|
return $packageJson.version
|
|
}
|
|
}
|
|
|
|
Write-Host "$YELLOW[警告]$NC 无法检测到 Cursor 版本"
|
|
Write-Host "$YELLOW[提示]$NC 请确保 Cursor 已正确安装"
|
|
return $null
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 获取 Cursor 版本失败: $_"
|
|
return $null
|
|
}
|
|
}
|
|
|
|
# 获取并显示版本信息
|
|
$cursorVersion = Get-CursorVersion
|
|
Write-Host ""
|
|
|
|
Write-Host "$YELLOW[重要提示]$NC 最新的 0.50.x (以支持)"
|
|
Write-Host ""
|
|
|
|
# 检查并关闭 Cursor 进程
|
|
Write-Host "$GREEN[信息]$NC 检查 Cursor 进程..."
|
|
|
|
function Get-ProcessDetails {
|
|
param($processName)
|
|
Write-Host "$BLUE[调试]$NC 正在获取 $processName 进程详细信息:"
|
|
Get-WmiObject Win32_Process -Filter "name='$processName'" |
|
|
Select-Object ProcessId, ExecutablePath, CommandLine |
|
|
Format-List
|
|
}
|
|
|
|
# 定义最大重试次数和等待时间
|
|
$MAX_RETRIES = 5
|
|
$WAIT_TIME = 1
|
|
|
|
# 处理进程关闭
|
|
function Close-CursorProcess {
|
|
param($processName)
|
|
|
|
$process = Get-Process -Name $processName -ErrorAction SilentlyContinue
|
|
if ($process) {
|
|
Write-Host "$YELLOW[警告]$NC 发现 $processName 正在运行"
|
|
Get-ProcessDetails $processName
|
|
|
|
Write-Host "$YELLOW[警告]$NC 尝试关闭 $processName..."
|
|
Stop-Process -Name $processName -Force
|
|
|
|
$retryCount = 0
|
|
while ($retryCount -lt $MAX_RETRIES) {
|
|
$process = Get-Process -Name $processName -ErrorAction SilentlyContinue
|
|
if (-not $process) { break }
|
|
|
|
$retryCount++
|
|
if ($retryCount -ge $MAX_RETRIES) {
|
|
Write-Host "$RED[错误]$NC 在 $MAX_RETRIES 次尝试后仍无法关闭 $processName"
|
|
Get-ProcessDetails $processName
|
|
Write-Host "$RED[错误]$NC 请手动关闭进程后重试"
|
|
Read-Host "按回车键退出"
|
|
exit 1
|
|
}
|
|
Write-Host "$YELLOW[警告]$NC 等待进程关闭,尝试 $retryCount/$MAX_RETRIES..."
|
|
Start-Sleep -Seconds $WAIT_TIME
|
|
}
|
|
Write-Host "$GREEN[信息]$NC $processName 已成功关闭"
|
|
}
|
|
}
|
|
|
|
# 关闭所有 Cursor 进程
|
|
Close-CursorProcess "Cursor"
|
|
Close-CursorProcess "cursor"
|
|
|
|
# 执行 Cursor 初始化清理
|
|
Cursor-初始化
|
|
|
|
# 创建备份目录
|
|
if (-not (Test-Path $BACKUP_DIR)) {
|
|
New-Item -ItemType Directory -Path $BACKUP_DIR | Out-Null
|
|
}
|
|
|
|
# 备份现有配置
|
|
if (Test-Path $STORAGE_FILE) {
|
|
Write-Host "$GREEN[信息]$NC 正在备份配置文件..."
|
|
$backupName = "storage.json.backup_$(Get-Date -Format 'yyyyMMdd_HHmmss')"
|
|
Copy-Item $STORAGE_FILE "$BACKUP_DIR\$backupName"
|
|
}
|
|
|
|
# 生成新的 ID
|
|
Write-Host "$GREEN[信息]$NC 正在生成新的 ID..."
|
|
|
|
# 在颜色定义后添加此函数
|
|
function Get-RandomHex {
|
|
param (
|
|
[int]$length
|
|
)
|
|
|
|
$bytes = New-Object byte[] ($length)
|
|
$rng = [System.Security.Cryptography.RNGCryptoServiceProvider]::new()
|
|
$rng.GetBytes($bytes)
|
|
$hexString = [System.BitConverter]::ToString($bytes) -replace '-',''
|
|
$rng.Dispose()
|
|
return $hexString
|
|
}
|
|
|
|
# 改进 ID 生成函数
|
|
function New-StandardMachineId {
|
|
$template = "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx"
|
|
$result = $template -replace '[xy]', {
|
|
param($match)
|
|
$r = [Random]::new().Next(16)
|
|
$v = if ($match.Value -eq "x") { $r } else { ($r -band 0x3) -bor 0x8 }
|
|
return $v.ToString("x")
|
|
}
|
|
return $result
|
|
}
|
|
|
|
# 在生成 ID 时使用新函数
|
|
$MAC_MACHINE_ID = New-StandardMachineId
|
|
$UUID = [System.Guid]::NewGuid().ToString()
|
|
# 将 auth0|user_ 转换为字节数组的十六进制
|
|
$prefixBytes = [System.Text.Encoding]::UTF8.GetBytes("auth0|user_")
|
|
$prefixHex = -join ($prefixBytes | ForEach-Object { '{0:x2}' -f $_ })
|
|
# 生成32字节(64个十六进制字符)的随机数作为 machineId 的随机部分
|
|
$randomPart = Get-RandomHex -length 32
|
|
$MACHINE_ID = "$prefixHex$randomPart"
|
|
$SQM_ID = "{$([System.Guid]::NewGuid().ToString().ToUpper())}"
|
|
|
|
# 在Update-MachineGuid函数前添加权限检查
|
|
if (-NOT ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] "Administrator")) {
|
|
Write-Host "$RED[错误]$NC 请使用管理员权限运行此脚本"
|
|
Start-Process powershell "-NoProfile -ExecutionPolicy Bypass -File `"$PSCommandPath`"" -Verb RunAs
|
|
exit
|
|
}
|
|
|
|
function Update-MachineGuid {
|
|
try {
|
|
# 检查注册表路径是否存在,不存在则创建
|
|
$registryPath = "HKLM:\SOFTWARE\Microsoft\Cryptography"
|
|
if (-not (Test-Path $registryPath)) {
|
|
Write-Host "$YELLOW[警告]$NC 注册表路径不存在: $registryPath,正在创建..."
|
|
New-Item -Path $registryPath -Force | Out-Null
|
|
Write-Host "$GREEN[信息]$NC 注册表路径创建成功"
|
|
}
|
|
|
|
# 获取当前的 MachineGuid,如果不存在则使用空字符串作为默认值
|
|
$originalGuid = ""
|
|
try {
|
|
$currentGuid = Get-ItemProperty -Path $registryPath -Name MachineGuid -ErrorAction SilentlyContinue
|
|
if ($currentGuid) {
|
|
$originalGuid = $currentGuid.MachineGuid
|
|
Write-Host "$GREEN[信息]$NC 当前注册表值:"
|
|
Write-Host "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography"
|
|
Write-Host " MachineGuid REG_SZ $originalGuid"
|
|
} else {
|
|
Write-Host "$YELLOW[警告]$NC MachineGuid 值不存在,将创建新值"
|
|
}
|
|
} catch {
|
|
Write-Host "$YELLOW[警告]$NC 获取 MachineGuid 失败: $($_.Exception.Message)"
|
|
}
|
|
|
|
# 创建备份目录(如果不存在)
|
|
if (-not (Test-Path $BACKUP_DIR)) {
|
|
New-Item -ItemType Directory -Path $BACKUP_DIR -Force | Out-Null
|
|
}
|
|
|
|
# 创建备份文件(仅当原始值存在时)
|
|
if ($originalGuid) {
|
|
$backupFile = "$BACKUP_DIR\MachineGuid_$(Get-Date -Format 'yyyyMMdd_HHmmss').reg"
|
|
$backupResult = Start-Process "reg.exe" -ArgumentList "export", "`"HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography`"", "`"$backupFile`"" -NoNewWindow -Wait -PassThru
|
|
|
|
if ($backupResult.ExitCode -eq 0) {
|
|
Write-Host "$GREEN[信息]$NC 注册表项已备份到:$backupFile"
|
|
} else {
|
|
Write-Host "$YELLOW[警告]$NC 备份创建失败,继续执行..."
|
|
}
|
|
}
|
|
|
|
# 生成新GUID
|
|
$newGuid = [System.Guid]::NewGuid().ToString()
|
|
|
|
# 更新或创建注册表值
|
|
Set-ItemProperty -Path $registryPath -Name MachineGuid -Value $newGuid -Force -ErrorAction Stop
|
|
|
|
# 验证更新
|
|
$verifyGuid = (Get-ItemProperty -Path $registryPath -Name MachineGuid -ErrorAction Stop).MachineGuid
|
|
if ($verifyGuid -ne $newGuid) {
|
|
throw "注册表验证失败:更新后的值 ($verifyGuid) 与预期值 ($newGuid) 不匹配"
|
|
}
|
|
|
|
Write-Host "$GREEN[信息]$NC 注册表更新成功:"
|
|
Write-Host "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography"
|
|
Write-Host " MachineGuid REG_SZ $newGuid"
|
|
return $true
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 注册表操作失败:$($_.Exception.Message)"
|
|
|
|
# 尝试恢复备份(如果存在)
|
|
if (($backupFile -ne $null) -and (Test-Path $backupFile)) {
|
|
Write-Host "$YELLOW[恢复]$NC 正在从备份恢复..."
|
|
$restoreResult = Start-Process "reg.exe" -ArgumentList "import", "`"$backupFile`"" -NoNewWindow -Wait -PassThru
|
|
|
|
if ($restoreResult.ExitCode -eq 0) {
|
|
Write-Host "$GREEN[恢复成功]$NC 已还原原始注册表值"
|
|
} else {
|
|
Write-Host "$RED[错误]$NC 恢复失败,请手动导入备份文件:$backupFile"
|
|
}
|
|
} else {
|
|
Write-Host "$YELLOW[警告]$NC 未找到备份文件或备份创建失败,无法自动恢复"
|
|
}
|
|
return $false
|
|
}
|
|
}
|
|
|
|
# 创建或更新配置文件
|
|
Write-Host "$GREEN[信息]$NC 正在更新配置..."
|
|
|
|
try {
|
|
# 检查配置文件是否存在
|
|
if (-not (Test-Path $STORAGE_FILE)) {
|
|
Write-Host "$RED[错误]$NC 未找到配置文件: $STORAGE_FILE"
|
|
Write-Host "$YELLOW[提示]$NC 请先安装并运行一次 Cursor 后再使用此脚本"
|
|
Read-Host "按回车键退出"
|
|
exit 1
|
|
}
|
|
|
|
# 读取现有配置文件
|
|
try {
|
|
$originalContent = Get-Content $STORAGE_FILE -Raw -Encoding UTF8
|
|
|
|
# 将 JSON 字符串转换为 PowerShell 对象
|
|
$config = $originalContent | ConvertFrom-Json
|
|
|
|
# 备份当前值
|
|
$oldValues = @{
|
|
'machineId' = $config.'telemetry.machineId'
|
|
'macMachineId' = $config.'telemetry.macMachineId'
|
|
'devDeviceId' = $config.'telemetry.devDeviceId'
|
|
'sqmId' = $config.'telemetry.sqmId'
|
|
}
|
|
|
|
# 更新特定的值
|
|
$config.'telemetry.machineId' = $MACHINE_ID
|
|
$config.'telemetry.macMachineId' = $MAC_MACHINE_ID
|
|
$config.'telemetry.devDeviceId' = $UUID
|
|
$config.'telemetry.sqmId' = $SQM_ID
|
|
|
|
# 将更新后的对象转换回 JSON 并保存
|
|
$updatedJson = $config | ConvertTo-Json -Depth 10
|
|
[System.IO.File]::WriteAllText(
|
|
[System.IO.Path]::GetFullPath($STORAGE_FILE),
|
|
$updatedJson,
|
|
[System.Text.Encoding]::UTF8
|
|
)
|
|
Write-Host "$GREEN[信息]$NC 成功更新配置文件"
|
|
} catch {
|
|
# 如果出错,尝试恢复原始内容
|
|
if ($originalContent) {
|
|
[System.IO.File]::WriteAllText(
|
|
[System.IO.Path]::GetFullPath($STORAGE_FILE),
|
|
$originalContent,
|
|
[System.Text.Encoding]::UTF8
|
|
)
|
|
}
|
|
throw "处理 JSON 失败: $_"
|
|
}
|
|
# 直接执行更新 MachineGuid,不再询问
|
|
Update-MachineGuid
|
|
# 显示结果
|
|
Write-Host ""
|
|
Write-Host "$GREEN[信息]$NC 已更新配置:"
|
|
Write-Host "$BLUE[调试]$NC machineId: $MACHINE_ID"
|
|
Write-Host "$BLUE[调试]$NC macMachineId: $MAC_MACHINE_ID"
|
|
Write-Host "$BLUE[调试]$NC devDeviceId: $UUID"
|
|
Write-Host "$BLUE[调试]$NC sqmId: $SQM_ID"
|
|
|
|
# 显示文件树结构
|
|
Write-Host ""
|
|
Write-Host "$GREEN[信息]$NC 文件结构:"
|
|
Write-Host "$BLUE$env:APPDATA\Cursor\User$NC"
|
|
Write-Host "├── globalStorage"
|
|
Write-Host "│ ├── storage.json (已修改)"
|
|
Write-Host "│ └── backups"
|
|
|
|
# 列出备份文件
|
|
$backupFiles = Get-ChildItem "$BACKUP_DIR\*" -ErrorAction SilentlyContinue
|
|
if ($backupFiles) {
|
|
foreach ($file in $backupFiles) {
|
|
Write-Host "│ └── $($file.Name)"
|
|
}
|
|
} else {
|
|
Write-Host "│ └── (空)"
|
|
}
|
|
|
|
# 显示公众号信息
|
|
Write-Host ""
|
|
Write-Host "$GREEN================================$NC"
|
|
Write-Host "$YELLOW 关注公众号【煎饼果子卷AI】一起交流更多Cursor技巧和AI知识(脚本免费、关注公众号加群有更多技巧和大佬) $NC"
|
|
Write-Host "$GREEN================================$NC"
|
|
Write-Host ""
|
|
Write-Host "$GREEN[信息]$NC 请重启 Cursor 以应用新的配置"
|
|
Write-Host ""
|
|
|
|
# 询问是否要禁用自动更新
|
|
Write-Host ""
|
|
Write-Host "$YELLOW[询问]$NC 是否要禁用 Cursor 自动更新功能?"
|
|
Write-Host "0) 否 - 保持默认设置 (按回车键)"
|
|
Write-Host "1) 是 - 禁用自动更新"
|
|
$choice = Read-Host "请输入选项 (0)"
|
|
|
|
if ($choice -eq "1") {
|
|
Write-Host ""
|
|
Write-Host "$GREEN[信息]$NC 正在处理自动更新..."
|
|
$updaterPath = "$env:LOCALAPPDATA\cursor-updater"
|
|
|
|
# 定义手动设置教程
|
|
function Show-ManualGuide {
|
|
Write-Host ""
|
|
Write-Host "$YELLOW[警告]$NC 自动设置失败,请尝试手动操作:"
|
|
Write-Host "$YELLOW手动禁用更新步骤:$NC"
|
|
Write-Host "1. 以管理员身份打开 PowerShell"
|
|
Write-Host "2. 复制粘贴以下命令:"
|
|
Write-Host "$BLUE命令1 - 删除现有目录(如果存在):$NC"
|
|
Write-Host "Remove-Item -Path `"$updaterPath`" -Force -Recurse -ErrorAction SilentlyContinue"
|
|
Write-Host ""
|
|
Write-Host "$BLUE命令2 - 创建阻止文件:$NC"
|
|
Write-Host "New-Item -Path `"$updaterPath`" -ItemType File -Force | Out-Null"
|
|
Write-Host ""
|
|
Write-Host "$BLUE命令3 - 设置只读属性:$NC"
|
|
Write-Host "Set-ItemProperty -Path `"$updaterPath`" -Name IsReadOnly -Value `$true"
|
|
Write-Host ""
|
|
Write-Host "$BLUE命令4 - 设置权限(可选):$NC"
|
|
Write-Host "icacls `"$updaterPath`" /inheritance:r /grant:r `"`$($env:USERNAME):(R)`""
|
|
Write-Host ""
|
|
Write-Host "$YELLOW验证方法:$NC"
|
|
Write-Host "1. 运行命令:Get-ItemProperty `"$updaterPath`""
|
|
Write-Host "2. 确认 IsReadOnly 属性为 True"
|
|
Write-Host "3. 运行命令:icacls `"$updaterPath`""
|
|
Write-Host "4. 确认只有读取权限"
|
|
Write-Host ""
|
|
Write-Host "$YELLOW[提示]$NC 完成后请重启 Cursor"
|
|
}
|
|
|
|
try {
|
|
# 检查cursor-updater是否存在
|
|
if (Test-Path $updaterPath) {
|
|
# 如果是文件,说明已经创建了阻止更新
|
|
if ((Get-Item $updaterPath) -is [System.IO.FileInfo]) {
|
|
Write-Host "$GREEN[信息]$NC 已创建阻止更新文件,无需再次阻止"
|
|
return
|
|
}
|
|
# 如果是目录,尝试删除
|
|
else {
|
|
try {
|
|
Remove-Item -Path $updaterPath -Force -Recurse -ErrorAction Stop
|
|
Write-Host "$GREEN[信息]$NC 成功删除 cursor-updater 目录"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 删除 cursor-updater 目录失败"
|
|
Show-ManualGuide
|
|
return
|
|
}
|
|
}
|
|
}
|
|
|
|
# 创建阻止文件
|
|
try {
|
|
New-Item -Path $updaterPath -ItemType File -Force -ErrorAction Stop | Out-Null
|
|
Write-Host "$GREEN[信息]$NC 成功创建阻止文件"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 创建阻止文件失败"
|
|
Show-ManualGuide
|
|
return
|
|
}
|
|
|
|
# 设置文件权限
|
|
try {
|
|
# 设置只读属性
|
|
Set-ItemProperty -Path $updaterPath -Name IsReadOnly -Value $true -ErrorAction Stop
|
|
|
|
# 使用 icacls 设置权限
|
|
$result = Start-Process "icacls.exe" -ArgumentList "`"$updaterPath`" /inheritance:r /grant:r `"$($env:USERNAME):(R)`"" -Wait -NoNewWindow -PassThru
|
|
if ($result.ExitCode -ne 0) {
|
|
throw "icacls 命令失败"
|
|
}
|
|
|
|
Write-Host "$GREEN[信息]$NC 成功设置文件权限"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 设置文件权限失败"
|
|
Show-ManualGuide
|
|
return
|
|
}
|
|
|
|
# 验证设置
|
|
try {
|
|
$fileInfo = Get-ItemProperty $updaterPath
|
|
if (-not $fileInfo.IsReadOnly) {
|
|
Write-Host "$RED[错误]$NC 验证失败:文件权限设置可能未生效"
|
|
Show-ManualGuide
|
|
return
|
|
}
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 验证设置失败"
|
|
Show-ManualGuide
|
|
return
|
|
}
|
|
|
|
Write-Host "$GREEN[信息]$NC 成功禁用自动更新"
|
|
}
|
|
catch {
|
|
Write-Host "$RED[错误]$NC 发生未知错误: $_"
|
|
Show-ManualGuide
|
|
}
|
|
}
|
|
else {
|
|
Write-Host "$GREEN[信息]$NC 保持默认设置,不进行更改"
|
|
}
|
|
|
|
# 保留有效的注册表更新
|
|
Update-MachineGuid
|
|
|
|
} catch {
|
|
Write-Host "$RED[错误]$NC 主要操作失败: $_"
|
|
Write-Host "$YELLOW[尝试]$NC 使用备选方法..."
|
|
|
|
try {
|
|
# 备选方法:使用 Add-Content
|
|
$tempFile = [System.IO.Path]::GetTempFileName()
|
|
$config | ConvertTo-Json | Set-Content -Path $tempFile -Encoding UTF8
|
|
Copy-Item -Path $tempFile -Destination $STORAGE_FILE -Force
|
|
Remove-Item -Path $tempFile
|
|
Write-Host "$GREEN[信息]$NC 使用备选方法成功写入配置"
|
|
} catch {
|
|
Write-Host "$RED[错误]$NC 所有尝试都失败了"
|
|
Write-Host "错误详情: $_"
|
|
Write-Host "目标文件: $STORAGE_FILE"
|
|
Write-Host "请确保您有足够的权限访问该文件"
|
|
Read-Host "按回车键退出"
|
|
exit 1
|
|
}
|
|
}
|
|
|
|
Write-Host ""
|
|
Read-Host "按回车键退出"
|
|
exit 0
|
|
|
|
# 在文件写入部分修改
|
|
function Write-ConfigFile {
|
|
param($config, $filePath)
|
|
|
|
try {
|
|
# 使用 UTF8 无 BOM 编码
|
|
$utf8NoBom = New-Object System.Text.UTF8Encoding $false
|
|
$jsonContent = $config | ConvertTo-Json -Depth 10
|
|
|
|
# 统一使用 LF 换行符
|
|
$jsonContent = $jsonContent.Replace("`r`n", "`n")
|
|
|
|
[System.IO.File]::WriteAllText(
|
|
[System.IO.Path]::GetFullPath($filePath),
|
|
$jsonContent,
|
|
$utf8NoBom
|
|
)
|
|
|
|
Write-Host "$GREEN[信息]$NC 成功写入配置文件(UTF8 无 BOM)"
|
|
}
|
|
catch {
|
|
throw "写入配置文件失败: $_"
|
|
}
|
|
}
|