tt-help-cli-ycl 1.3.44 → 1.3.46

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/README.md +33 -33
  2. package/cli.js +9 -9
  3. package/package.json +52 -52
  4. package/scripts/run-explore copy.bat +101 -101
  5. package/scripts/run-explore.bat +134 -134
  6. package/scripts/run-explore.ps1 +159 -159
  7. package/scripts/run-explore.sh +121 -121
  8. package/src/cli/attach.js +331 -301
  9. package/src/cli/auto.js +265 -265
  10. package/src/cli/comments.js +620 -620
  11. package/src/cli/config.js +170 -170
  12. package/src/cli/db-import.js +51 -51
  13. package/src/cli/explore.js +555 -555
  14. package/src/cli/info.js +10 -16
  15. package/src/cli/open.js +111 -111
  16. package/src/cli/progress.js +111 -111
  17. package/src/cli/refresh.js +288 -288
  18. package/src/cli/scrape.js +47 -47
  19. package/src/cli/utils.js +18 -18
  20. package/src/cli/videos.js +41 -41
  21. package/src/cli/videostats.js +196 -196
  22. package/src/cli/watch.js +30 -30
  23. package/src/cli/webserver.js +19 -0
  24. package/src/lib/api-interceptor.js +161 -161
  25. package/src/lib/args.js +809 -771
  26. package/src/lib/browser/anti-detect.js +23 -23
  27. package/src/lib/browser/cdp.js +261 -261
  28. package/src/lib/browser/health-checker.js +114 -114
  29. package/src/lib/browser/launch.js +43 -43
  30. package/src/lib/browser/page.js +184 -184
  31. package/src/lib/constants.js +297 -285
  32. package/src/lib/delay.js +54 -54
  33. package/src/lib/explore-fetch.js +118 -118
  34. package/src/lib/fetcher.js +45 -45
  35. package/src/lib/filter.js +66 -66
  36. package/src/lib/io.js +54 -54
  37. package/src/lib/output.js +80 -80
  38. package/src/lib/page-error-detector.js +109 -109
  39. package/src/lib/parse-ssr.mjs +69 -69
  40. package/src/lib/parser.js +47 -47
  41. package/src/lib/retry.js +45 -45
  42. package/src/lib/scrape.js +90 -89
  43. package/src/lib/target-locations.js +61 -61
  44. package/src/lib/tiktok-scraper.mjs +160 -106
  45. package/src/lib/url.js +52 -52
  46. package/src/main.js +73 -70
  47. package/src/npm-main.js +70 -69
  48. package/src/scraper/auto-core.js +203 -203
  49. package/src/scraper/core.js +255 -255
  50. package/src/scraper/explore-core.js +208 -208
  51. package/src/scraper/modules/captcha-handler.js +114 -114
  52. package/src/scraper/modules/follow-extractor.js +250 -250
  53. package/src/scraper/modules/guess-extractor.js +51 -51
  54. package/src/scraper/modules/page-helpers.js +48 -48
  55. package/src/scraper/refresh-core.js +213 -213
  56. package/src/videos/core.js +143 -143
  57. package/src/watch/data-store.js +2980 -2846
  58. package/src/watch/public/index.html +2355 -2285
  59. package/src/watch/server.js +727 -711
  60. package/src/webserver/server.mjs +174 -0
  61. package/scripts/test-captcha-lib.mjs +0 -68
  62. package/scripts/test-captcha.mjs +0 -81
  63. package/scripts/test-incognito-lib.mjs +0 -36
  64. package/scripts/test-login-state.mjs +0 -128
  65. package/scripts/test-safe-click.mjs +0 -45
  66. package/scripts/test-watch-db-smoke.mjs +0 -246
  67. package/src/results/user-videos-bar.lar.lar.moeta.json +0 -37
@@ -1,134 +1,134 @@
1
- @ECHO OFF
2
- SETLOCAL EnableDelayedExpansion
3
-
4
- SET "PACKAGENAME=tt-help-cli-ycl"
5
- SET "CONFIG_PATH=%USERPROFILE%\.tt-help.json"
6
-
7
- ECHO ========================================
8
- ECHO tt-help-cli-ycl one-click launcher (Windows CMD)
9
- ECHO ========================================
10
-
11
- REM ---------- 0. Auto-select server based on local IP ----------
12
- SET "TARGET_SERVER=http://117.71.53.99:17301"
13
- SET "LOCAL_IP="
14
- SET "GET_IP_PS1=%TEMP%\tt_get_local_ip.ps1"
15
- >"%GET_IP_PS1%" ECHO $ip = $null
16
- >>"%GET_IP_PS1%" ECHO try {
17
- >>"%GET_IP_PS1%" ECHO $ip = Get-WmiObject Win32_NetworkAdapterConfiguration ^| Where-Object { $_.IPEnabled -eq $true } ^| ForEach-Object { $_.IPAddress } ^| Where-Object { $_ -match '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$' -and $_ -ne '127.0.0.1' -and $_ -notlike '169.254.*' } ^| Select-Object -First 1
18
- >>"%GET_IP_PS1%" ECHO } catch {}
19
- >>"%GET_IP_PS1%" ECHO if (-not $ip) {
20
- >>"%GET_IP_PS1%" ECHO try {
21
- >>"%GET_IP_PS1%" ECHO $ip = Get-NetIPAddress -AddressFamily IPv4 -ErrorAction Stop ^| Where-Object { $_.IPAddress -ne '127.0.0.1' -and $_.IPAddress -notlike '169.254.*' } ^| Select-Object -First 1 -ExpandProperty IPAddress
22
- >>"%GET_IP_PS1%" ECHO } catch {}
23
- >>"%GET_IP_PS1%" ECHO }
24
- >>"%GET_IP_PS1%" ECHO if (-not $ip) {
25
- >>"%GET_IP_PS1%" ECHO try {
26
- >>"%GET_IP_PS1%" ECHO $ip = [System.Net.Dns]::GetHostAddresses([System.Net.Dns]::GetHostName()) ^| Where-Object { $_.AddressFamily -eq [System.Net.Sockets.AddressFamily]::InterNetwork -and $_.IPAddressToString -ne '127.0.0.1' -and $_.IPAddressToString -notlike '169.254.*' } ^| Select-Object -First 1 -ExpandProperty IPAddressToString
27
- >>"%GET_IP_PS1%" ECHO } catch {}
28
- >>"%GET_IP_PS1%" ECHO }
29
- >>"%GET_IP_PS1%" ECHO if ($ip) { [Console]::Write($ip) }
30
- FOR /F "usebackq delims=" %%I IN (`powershell -NoProfile -ExecutionPolicy Bypass -File "%GET_IP_PS1%"`) DO (
31
- SET "LOCAL_IP=%%I"
32
- )
33
-
34
- ECHO [INFO] Local IP: %LOCAL_IP%
35
-
36
- IF DEFINED LOCAL_IP IF "%LOCAL_IP:~0,11%"=="172.18.154." SET "TARGET_SERVER=http://172.18.154.201:3001"
37
-
38
- IF NOT DEFINED LOCAL_IP (
39
- ECHO [INFO] No local IPv4 detected, using public server
40
- ) ELSE IF "%LOCAL_IP:~0,11%"=="172.18.154." (
41
- ECHO [INFO] Intranet IP detected, using intranet server
42
- ) ELSE (
43
- ECHO [INFO] No intranet IP detected, using public server
44
- )
45
- DEL "%GET_IP_PS1%" 2>NUL
46
-
47
- REM ---------- 1. Check/install latest version ----------
48
- FOR /F "delims=" %%V IN ('npm view %PACKAGENAME% version 2^>nul') DO SET "LATEST_VERSION=%%V"
49
-
50
- IF NOT DEFINED LATEST_VERSION (
51
- ECHO [ERROR] Cannot get latest version from npm
52
- EXIT /B 1
53
- )
54
-
55
- FOR /F "tokens=2 delims=@" %%V IN ('npm list -g %PACKAGENAME% --depth=0 2^>nul ^| findstr /i "%PACKAGENAME%"') DO SET "INSTALLED_VERSION=%%V"
56
-
57
- IF NOT DEFINED INSTALLED_VERSION (
58
- ECHO [INFO] %PACKAGENAME% not installed, installing latest...
59
- CALL npm install -g %PACKAGENAME%
60
- IF %ERRORLEVEL% EQU 0 (
61
- ECHO [OK] Installed: %LATEST_VERSION%
62
- ) ELSE (
63
- ECHO [ERROR] Install failed, run manually: npm install -g %PACKAGENAME%
64
- EXIT /B 1
65
- )
66
- ) ELSE IF "%INSTALLED_VERSION%"=="%LATEST_VERSION%" (
67
- ECHO [OK] %PACKAGENAME% is up to date: %LATEST_VERSION%
68
- ) ELSE (
69
- ECHO [INFO] Current: %INSTALLED_VERSION%, Latest: %LATEST_VERSION%
70
- ECHO [INFO] Upgrading to latest...
71
- CALL npm install -g %PACKAGENAME%
72
- IF %ERRORLEVEL% EQU 0 (
73
- ECHO [OK] Upgraded: %LATEST_VERSION%
74
- ) ELSE (
75
- ECHO [WARN] Upgrade failed, run manually: npm install -g %PACKAGENAME%
76
- )
77
- )
78
-
79
- REM ---------- 2. Check/set server config ----------
80
- SET "CURRENT_SERVER="
81
- IF EXIST "%CONFIG_PATH%" (
82
- FOR /F "usebackq delims=" %%S IN (`powershell -NoProfile -Command "$p=$env:CONFIG_PATH; if (Test-Path $p) { try { $cfg = Get-Content $p -Raw | ConvertFrom-Json; if ($null -ne $cfg.server) { [Console]::Write($cfg.server) } } catch {} }"`) DO SET "CURRENT_SERVER=%%S"
83
- )
84
-
85
- IF "%CURRENT_SERVER%"=="%TARGET_SERVER%" (
86
- ECHO [OK] Server config is correct: %TARGET_SERVER%
87
- ) ELSE (
88
- IF "%CURRENT_SERVER%"=="" (
89
- ECHO [INFO] Current server: not set, target: %TARGET_SERVER%
90
- ) ELSE (
91
- ECHO [INFO] Current server: %CURRENT_SERVER%, target: %TARGET_SERVER%
92
- )
93
- ECHO [INFO] Setting server config...
94
- node -e "const fs=require('fs'),path=require('path');const p=path.join(require('os').homedir(),'.tt-help.json');let c={};try{c=JSON.parse(fs.readFileSync(p,'utf-8'))}catch(e){}c.server='%TARGET_SERVER%';fs.writeFileSync(p,JSON.stringify(c,null,2),'utf-8');console.log(' Written to: '+p);"
95
- ECHO [OK] Server config set
96
- )
97
-
98
- REM ---------- 3. Ask user for parameters ----------
99
- ECHO.
100
- ECHO ========================================
101
- ECHO Parameter Configuration
102
- ECHO ========================================
103
-
104
- SET /P "BASE_PORT=Base port (--base-port) [default: 9222]: "
105
- IF "%BASE_PORT%"=="" SET "BASE_PORT=9222"
106
-
107
- SET /P "PORT_COUNT=Port count (--port-count) [default: 10]: "
108
- IF "%PORT_COUNT%"=="" SET "PORT_COUNT=10"
109
-
110
- SET /P "JOB_LOCATIONS=Job locations (--job-locations) [default: none]: "
111
- SET "JOB_LOC_ARGS="
112
- IF NOT "%JOB_LOCATIONS%"=="" SET "JOB_LOC_ARGS=--job-locations %JOB_LOCATIONS%"
113
-
114
- REM ---------- 4. Get user ID from config and compose ----------
115
- SET "CONFIG_USER_ID=user"
116
- IF EXIST "%CONFIG_PATH%" (
117
- FOR /F "usebackq delims=" %%S IN (`powershell -NoProfile -Command "$p=$env:CONFIG_PATH; if (Test-Path $p) { try { $cfg = Get-Content $p -Raw | ConvertFrom-Json; if ($null -ne $cfg.userId) { [Console]::Write($cfg.userId) } } catch {} }"`) DO SET "CONFIG_USER_ID=%%S"
118
- )
119
- CALL SET "USER_ID=%%CONFIG_USER_ID%%_%%BASE_PORT%%_%%PORT_COUNT%%"
120
-
121
- REM ---------- 5. Start tt-help explore ----------
122
- ECHO.
123
- ECHO ========================================
124
- ECHO Starting tt-help explore
125
- ECHO ========================================
126
- CALL ECHO User ID: %%USER_ID%%
127
- CALL ECHO Base port: %%BASE_PORT%%
128
- CALL ECHO Port count: %%PORT_COUNT%%
129
- IF NOT "%JOB_LOCATIONS%"=="" ECHO Job locations: %JOB_LOCATIONS%
130
- ECHO Max following: 5
131
- ECHO Max followers: 5
132
- ECHO Speed: stealth (slowest)
133
- ECHO ========================================
134
- CALL tt-help explore stealth --user-id %%USER_ID%% --base-port %%BASE_PORT%% --port-count %%PORT_COUNT%% --max-following 5 --max-followers 5 %%JOB_LOC_ARGS%%
1
+ @ECHO OFF
2
+ SETLOCAL EnableDelayedExpansion
3
+
4
+ SET "PACKAGENAME=tt-help-cli-ycl"
5
+ SET "CONFIG_PATH=%USERPROFILE%\.tt-help.json"
6
+
7
+ ECHO ========================================
8
+ ECHO tt-help-cli-ycl one-click launcher (Windows CMD)
9
+ ECHO ========================================
10
+
11
+ REM ---------- 0. Auto-select server based on local IP ----------
12
+ SET "TARGET_SERVER=http://117.71.53.99:17301"
13
+ SET "LOCAL_IP="
14
+ SET "GET_IP_PS1=%TEMP%\tt_get_local_ip.ps1"
15
+ >"%GET_IP_PS1%" ECHO $ip = $null
16
+ >>"%GET_IP_PS1%" ECHO try {
17
+ >>"%GET_IP_PS1%" ECHO $ip = Get-WmiObject Win32_NetworkAdapterConfiguration ^| Where-Object { $_.IPEnabled -eq $true } ^| ForEach-Object { $_.IPAddress } ^| Where-Object { $_ -match '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$' -and $_ -ne '127.0.0.1' -and $_ -notlike '169.254.*' } ^| Select-Object -First 1
18
+ >>"%GET_IP_PS1%" ECHO } catch {}
19
+ >>"%GET_IP_PS1%" ECHO if (-not $ip) {
20
+ >>"%GET_IP_PS1%" ECHO try {
21
+ >>"%GET_IP_PS1%" ECHO $ip = Get-NetIPAddress -AddressFamily IPv4 -ErrorAction Stop ^| Where-Object { $_.IPAddress -ne '127.0.0.1' -and $_.IPAddress -notlike '169.254.*' } ^| Select-Object -First 1 -ExpandProperty IPAddress
22
+ >>"%GET_IP_PS1%" ECHO } catch {}
23
+ >>"%GET_IP_PS1%" ECHO }
24
+ >>"%GET_IP_PS1%" ECHO if (-not $ip) {
25
+ >>"%GET_IP_PS1%" ECHO try {
26
+ >>"%GET_IP_PS1%" ECHO $ip = [System.Net.Dns]::GetHostAddresses([System.Net.Dns]::GetHostName()) ^| Where-Object { $_.AddressFamily -eq [System.Net.Sockets.AddressFamily]::InterNetwork -and $_.IPAddressToString -ne '127.0.0.1' -and $_.IPAddressToString -notlike '169.254.*' } ^| Select-Object -First 1 -ExpandProperty IPAddressToString
27
+ >>"%GET_IP_PS1%" ECHO } catch {}
28
+ >>"%GET_IP_PS1%" ECHO }
29
+ >>"%GET_IP_PS1%" ECHO if ($ip) { [Console]::Write($ip) }
30
+ FOR /F "usebackq delims=" %%I IN (`powershell -NoProfile -ExecutionPolicy Bypass -File "%GET_IP_PS1%"`) DO (
31
+ SET "LOCAL_IP=%%I"
32
+ )
33
+
34
+ ECHO [INFO] Local IP: %LOCAL_IP%
35
+
36
+ IF DEFINED LOCAL_IP IF "%LOCAL_IP:~0,11%"=="172.18.154." SET "TARGET_SERVER=http://172.18.154.201:3001"
37
+
38
+ IF NOT DEFINED LOCAL_IP (
39
+ ECHO [INFO] No local IPv4 detected, using public server
40
+ ) ELSE IF "%LOCAL_IP:~0,11%"=="172.18.154." (
41
+ ECHO [INFO] Intranet IP detected, using intranet server
42
+ ) ELSE (
43
+ ECHO [INFO] No intranet IP detected, using public server
44
+ )
45
+ DEL "%GET_IP_PS1%" 2>NUL
46
+
47
+ REM ---------- 1. Check/install latest version ----------
48
+ FOR /F "delims=" %%V IN ('npm view %PACKAGENAME% version 2^>nul') DO SET "LATEST_VERSION=%%V"
49
+
50
+ IF NOT DEFINED LATEST_VERSION (
51
+ ECHO [ERROR] Cannot get latest version from npm
52
+ EXIT /B 1
53
+ )
54
+
55
+ FOR /F "tokens=2 delims=@" %%V IN ('npm list -g %PACKAGENAME% --depth=0 2^>nul ^| findstr /i "%PACKAGENAME%"') DO SET "INSTALLED_VERSION=%%V"
56
+
57
+ IF NOT DEFINED INSTALLED_VERSION (
58
+ ECHO [INFO] %PACKAGENAME% not installed, installing latest...
59
+ CALL npm install -g %PACKAGENAME%
60
+ IF %ERRORLEVEL% EQU 0 (
61
+ ECHO [OK] Installed: %LATEST_VERSION%
62
+ ) ELSE (
63
+ ECHO [ERROR] Install failed, run manually: npm install -g %PACKAGENAME%
64
+ EXIT /B 1
65
+ )
66
+ ) ELSE IF "%INSTALLED_VERSION%"=="%LATEST_VERSION%" (
67
+ ECHO [OK] %PACKAGENAME% is up to date: %LATEST_VERSION%
68
+ ) ELSE (
69
+ ECHO [INFO] Current: %INSTALLED_VERSION%, Latest: %LATEST_VERSION%
70
+ ECHO [INFO] Upgrading to latest...
71
+ CALL npm install -g %PACKAGENAME%
72
+ IF %ERRORLEVEL% EQU 0 (
73
+ ECHO [OK] Upgraded: %LATEST_VERSION%
74
+ ) ELSE (
75
+ ECHO [WARN] Upgrade failed, run manually: npm install -g %PACKAGENAME%
76
+ )
77
+ )
78
+
79
+ REM ---------- 2. Check/set server config ----------
80
+ SET "CURRENT_SERVER="
81
+ IF EXIST "%CONFIG_PATH%" (
82
+ FOR /F "usebackq delims=" %%S IN (`powershell -NoProfile -Command "$p=$env:CONFIG_PATH; if (Test-Path $p) { try { $cfg = Get-Content $p -Raw | ConvertFrom-Json; if ($null -ne $cfg.server) { [Console]::Write($cfg.server) } } catch {} }"`) DO SET "CURRENT_SERVER=%%S"
83
+ )
84
+
85
+ IF "%CURRENT_SERVER%"=="%TARGET_SERVER%" (
86
+ ECHO [OK] Server config is correct: %TARGET_SERVER%
87
+ ) ELSE (
88
+ IF "%CURRENT_SERVER%"=="" (
89
+ ECHO [INFO] Current server: not set, target: %TARGET_SERVER%
90
+ ) ELSE (
91
+ ECHO [INFO] Current server: %CURRENT_SERVER%, target: %TARGET_SERVER%
92
+ )
93
+ ECHO [INFO] Setting server config...
94
+ node -e "const fs=require('fs'),path=require('path');const p=path.join(require('os').homedir(),'.tt-help.json');let c={};try{c=JSON.parse(fs.readFileSync(p,'utf-8'))}catch(e){}c.server='%TARGET_SERVER%';fs.writeFileSync(p,JSON.stringify(c,null,2),'utf-8');console.log(' Written to: '+p);"
95
+ ECHO [OK] Server config set
96
+ )
97
+
98
+ REM ---------- 3. Ask user for parameters ----------
99
+ ECHO.
100
+ ECHO ========================================
101
+ ECHO Parameter Configuration
102
+ ECHO ========================================
103
+
104
+ SET /P "BASE_PORT=Base port (--base-port) [default: 9222]: "
105
+ IF "%BASE_PORT%"=="" SET "BASE_PORT=9222"
106
+
107
+ SET /P "PORT_COUNT=Port count (--port-count) [default: 10]: "
108
+ IF "%PORT_COUNT%"=="" SET "PORT_COUNT=10"
109
+
110
+ SET /P "JOB_LOCATIONS=Job locations (--job-locations) [default: none]: "
111
+ SET "JOB_LOC_ARGS="
112
+ IF NOT "%JOB_LOCATIONS%"=="" SET "JOB_LOC_ARGS=--job-locations %JOB_LOCATIONS%"
113
+
114
+ REM ---------- 4. Get user ID from config and compose ----------
115
+ SET "CONFIG_USER_ID=user"
116
+ IF EXIST "%CONFIG_PATH%" (
117
+ FOR /F "usebackq delims=" %%S IN (`powershell -NoProfile -Command "$p=$env:CONFIG_PATH; if (Test-Path $p) { try { $cfg = Get-Content $p -Raw | ConvertFrom-Json; if ($null -ne $cfg.userId) { [Console]::Write($cfg.userId) } } catch {} }"`) DO SET "CONFIG_USER_ID=%%S"
118
+ )
119
+ CALL SET "USER_ID=%%CONFIG_USER_ID%%_%%BASE_PORT%%_%%PORT_COUNT%%"
120
+
121
+ REM ---------- 5. Start tt-help explore ----------
122
+ ECHO.
123
+ ECHO ========================================
124
+ ECHO Starting tt-help explore
125
+ ECHO ========================================
126
+ CALL ECHO User ID: %%USER_ID%%
127
+ CALL ECHO Base port: %%BASE_PORT%%
128
+ CALL ECHO Port count: %%PORT_COUNT%%
129
+ IF NOT "%JOB_LOCATIONS%"=="" ECHO Job locations: %JOB_LOCATIONS%
130
+ ECHO Max following: 5
131
+ ECHO Max followers: 5
132
+ ECHO Speed: stealth (slowest)
133
+ ECHO ========================================
134
+ CALL tt-help explore stealth --user-id %%USER_ID%% --base-port %%BASE_PORT%% --port-count %%PORT_COUNT%% --max-following 5 --max-followers 5 %%JOB_LOC_ARGS%%
@@ -1,159 +1,159 @@
1
- $packageName = "tt-help-cli-ycl"
2
- $configPath = Join-Path $env:USERPROFILE ".tt-help.json"
3
-
4
- Write-Host "========================================"
5
- Write-Host " tt-help-cli-ycl 一键启动脚本 (Windows)"
6
- Write-Host "========================================"
7
-
8
- # ---------- 0. 根据本机 IP 自动选择 server ----------
9
- $localIp = $null
10
- try {
11
- $localIp = Get-WmiObject Win32_NetworkAdapterConfiguration |
12
- Where-Object { $_.IPEnabled -eq $true } |
13
- ForEach-Object { $_.IPAddress } |
14
- Where-Object {
15
- $_ -match '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$' -and
16
- $_ -ne '127.0.0.1' -and
17
- $_ -notlike '169.254.*'
18
- } |
19
- Select-Object -First 1
20
- } catch {
21
- }
22
- if (-not $localIp) {
23
- try {
24
- $localIp = Get-NetIPAddress -AddressFamily IPv4 -ErrorAction Stop |
25
- Where-Object { $_.IPAddress -ne '127.0.0.1' -and $_.IPAddress -notlike '169.254.*' } |
26
- Select-Object -First 1 -ExpandProperty IPAddress
27
- } catch {
28
- }
29
- }
30
- if (-not $localIp) {
31
- try {
32
- $localIp = [System.Net.Dns]::GetHostAddresses([System.Net.Dns]::GetHostName()) |
33
- Where-Object {
34
- $_.AddressFamily -eq [System.Net.Sockets.AddressFamily]::InterNetwork -and
35
- $_.IPAddressToString -ne '127.0.0.1' -and
36
- $_.IPAddressToString -notlike '169.254.*'
37
- } |
38
- Select-Object -First 1 -ExpandProperty IPAddressToString
39
- } catch {
40
- }
41
- }
42
- Write-Host "[提示] 本机 IP: $(if ($localIp) { $localIp } else { '未检测到' })"
43
- if ($localIp -and $localIp -match '^172\.18\.154\.') {
44
- $targetServer = "http://172.18.154.201:3001"
45
- Write-Host "[提示] 检测到内网 IP: $localIp,使用内网 server"
46
- } else {
47
- $targetServer = "http://117.71.53.99:17301"
48
- Write-Host "[提示] 未检测到内网 IP,使用公网 server"
49
- }
50
-
51
- # ---------- 1. 检查/安装最新版本 ----------
52
- $latestVersion = npm view $packageName version 2>$null
53
-
54
- if (-not $latestVersion) {
55
- Write-Host "[错误] 无法从 npm 获取最新版本信息"
56
- exit 1
57
- }
58
-
59
- $installedVersion = ""
60
- $output = npm list -g $packageName --depth=0 2>$null
61
- if ($output -match "$packageName@([\d.]+)") {
62
- $installedVersion = $matches[1]
63
- }
64
-
65
- if (-not $installedVersion) {
66
- Write-Host "[提示] tt-help-cli-ycl 未安装,正在安装最新版本..."
67
- npm install -g $packageName 2>$null
68
- if ($LASTEXITCODE -eq 0) {
69
- Write-Host "[OK] 安装完成: $latestVersion"
70
- } else {
71
- Write-Host "[错误] 安装失败,请手动执行: npm install -g $packageName"
72
- exit 1
73
- }
74
- } elseif ($installedVersion -eq $latestVersion) {
75
- Write-Host "[OK] tt-help-cli-ycl 已是最新版本: $latestVersion"
76
- } else {
77
- Write-Host "[提示] 当前版本: $installedVersion, 最新版本: $latestVersion"
78
- Write-Host "[执行] 正在升级最新版本..."
79
- npm install -g $packageName 2>$null
80
- if ($LASTEXITCODE -eq 0) {
81
- Write-Host "[OK] 升级完成: $latestVersion"
82
- } else {
83
- Write-Host "[警告] 升级失败,请手动执行: npm install -g $packageName"
84
- }
85
- }
86
-
87
- # ---------- 2. 检查/设置 server 配置 ----------
88
- $currentServer = ""
89
- if (Test-Path $configPath) {
90
- try {
91
- $config = Get-Content $configPath -Raw | ConvertFrom-Json
92
- $currentServer = $config.server
93
- } catch {
94
- $currentServer = ""
95
- }
96
- }
97
-
98
- if ($currentServer -eq $targetServer) {
99
- Write-Host "[OK] Server 配置正确: $targetServer"
100
- } else {
101
- $currentDisplay = if ($currentServer) { $currentServer } else { "未设置" }
102
- Write-Host "[提示] 当前 server: $currentDisplay, 目标: $targetServer"
103
- Write-Host "[执行] 正在设置 server 配置..."
104
-
105
- node -e "
106
- const fs = require('fs');
107
- const path = require('path');
108
- const configPath = path.join(require('os').homedir(), '.tt-help.json');
109
- let cfg = {};
110
- try { cfg = JSON.parse(fs.readFileSync(configPath, 'utf-8')); } catch(e) {}
111
- cfg.server = '$targetServer';
112
- fs.writeFileSync(configPath, JSON.stringify(cfg, null, 2), 'utf-8');
113
- console.log(' 已写入: ' + configPath);
114
- "
115
- Write-Host "[OK] Server 配置已设置"
116
- }
117
-
118
- # ---------- 3. 询问用户参数 ----------
119
- Write-Host ""
120
- Write-Host "========================================"
121
- Write-Host " 参数配置"
122
- Write-Host "========================================"
123
-
124
- $inputBasePort = Read-Host "起始端口 (--base-port) [默认: 9222]"
125
- $basePort = if ($inputBasePort) { $inputBasePort } else { "9222" }
126
-
127
- $inputPortCount = Read-Host "端口数量 (--port-count) [默认: 10]"
128
- $portCount = if ($inputPortCount) { $inputPortCount } else { "10" }
129
-
130
- $inputJobLocations = Read-Host "任务国家 (--job-locations) [默认: 无,使用全部]"
131
- $jobLocationsArg = if ($inputJobLocations) { "--job-locations $inputJobLocations" } else { "" }
132
-
133
- # ---------- 4. 获取配置中的用户编号并拼接 ----------
134
- $configUserId = ""
135
- if (Test-Path $configPath) {
136
- try {
137
- $config = Get-Content $configPath -Raw | ConvertFrom-Json
138
- $configUserId = $config.userId
139
- } catch {
140
- $configUserId = ""
141
- }
142
- }
143
- if (-not $configUserId) { $configUserId = "user" }
144
- $userId = "${configUserId}_${basePort}_${portCount}"
145
-
146
- # ---------- 5. 启动 tt-help explore ----------
147
- Write-Host ""
148
- Write-Host "========================================"
149
- Write-Host " 启动 tt-help explore"
150
- Write-Host "========================================"
151
- Write-Host " 用户编号: $userId"
152
- Write-Host " 起始端口: $basePort"
153
- Write-Host " 端口数量: $portCount"
154
- if ($inputJobLocations) { Write-Host " 任务国家: $inputJobLocations" }
155
- Write-Host " 最大关注: 5"
156
- Write-Host " 最大粉丝: 5"
157
- Write-Host " 速度: stealth (最慢)"
158
- Write-Host "========================================"
159
- tt-help explore stealth --user-id $userId --base-port $basePort --port-count $portCount --max-following 5 --max-followers 5 $jobLocationsArg
1
+ $packageName = "tt-help-cli-ycl"
2
+ $configPath = Join-Path $env:USERPROFILE ".tt-help.json"
3
+
4
+ Write-Host "========================================"
5
+ Write-Host " tt-help-cli-ycl 一键启动脚本 (Windows)"
6
+ Write-Host "========================================"
7
+
8
+ # ---------- 0. 根据本机 IP 自动选择 server ----------
9
+ $localIp = $null
10
+ try {
11
+ $localIp = Get-WmiObject Win32_NetworkAdapterConfiguration |
12
+ Where-Object { $_.IPEnabled -eq $true } |
13
+ ForEach-Object { $_.IPAddress } |
14
+ Where-Object {
15
+ $_ -match '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$' -and
16
+ $_ -ne '127.0.0.1' -and
17
+ $_ -notlike '169.254.*'
18
+ } |
19
+ Select-Object -First 1
20
+ } catch {
21
+ }
22
+ if (-not $localIp) {
23
+ try {
24
+ $localIp = Get-NetIPAddress -AddressFamily IPv4 -ErrorAction Stop |
25
+ Where-Object { $_.IPAddress -ne '127.0.0.1' -and $_.IPAddress -notlike '169.254.*' } |
26
+ Select-Object -First 1 -ExpandProperty IPAddress
27
+ } catch {
28
+ }
29
+ }
30
+ if (-not $localIp) {
31
+ try {
32
+ $localIp = [System.Net.Dns]::GetHostAddresses([System.Net.Dns]::GetHostName()) |
33
+ Where-Object {
34
+ $_.AddressFamily -eq [System.Net.Sockets.AddressFamily]::InterNetwork -and
35
+ $_.IPAddressToString -ne '127.0.0.1' -and
36
+ $_.IPAddressToString -notlike '169.254.*'
37
+ } |
38
+ Select-Object -First 1 -ExpandProperty IPAddressToString
39
+ } catch {
40
+ }
41
+ }
42
+ Write-Host "[提示] 本机 IP: $(if ($localIp) { $localIp } else { '未检测到' })"
43
+ if ($localIp -and $localIp -match '^172\.18\.154\.') {
44
+ $targetServer = "http://172.18.154.201:3001"
45
+ Write-Host "[提示] 检测到内网 IP: $localIp,使用内网 server"
46
+ } else {
47
+ $targetServer = "http://117.71.53.99:17301"
48
+ Write-Host "[提示] 未检测到内网 IP,使用公网 server"
49
+ }
50
+
51
+ # ---------- 1. 检查/安装最新版本 ----------
52
+ $latestVersion = npm view $packageName version 2>$null
53
+
54
+ if (-not $latestVersion) {
55
+ Write-Host "[错误] 无法从 npm 获取最新版本信息"
56
+ exit 1
57
+ }
58
+
59
+ $installedVersion = ""
60
+ $output = npm list -g $packageName --depth=0 2>$null
61
+ if ($output -match "$packageName@([\d.]+)") {
62
+ $installedVersion = $matches[1]
63
+ }
64
+
65
+ if (-not $installedVersion) {
66
+ Write-Host "[提示] tt-help-cli-ycl 未安装,正在安装最新版本..."
67
+ npm install -g $packageName 2>$null
68
+ if ($LASTEXITCODE -eq 0) {
69
+ Write-Host "[OK] 安装完成: $latestVersion"
70
+ } else {
71
+ Write-Host "[错误] 安装失败,请手动执行: npm install -g $packageName"
72
+ exit 1
73
+ }
74
+ } elseif ($installedVersion -eq $latestVersion) {
75
+ Write-Host "[OK] tt-help-cli-ycl 已是最新版本: $latestVersion"
76
+ } else {
77
+ Write-Host "[提示] 当前版本: $installedVersion, 最新版本: $latestVersion"
78
+ Write-Host "[执行] 正在升级最新版本..."
79
+ npm install -g $packageName 2>$null
80
+ if ($LASTEXITCODE -eq 0) {
81
+ Write-Host "[OK] 升级完成: $latestVersion"
82
+ } else {
83
+ Write-Host "[警告] 升级失败,请手动执行: npm install -g $packageName"
84
+ }
85
+ }
86
+
87
+ # ---------- 2. 检查/设置 server 配置 ----------
88
+ $currentServer = ""
89
+ if (Test-Path $configPath) {
90
+ try {
91
+ $config = Get-Content $configPath -Raw | ConvertFrom-Json
92
+ $currentServer = $config.server
93
+ } catch {
94
+ $currentServer = ""
95
+ }
96
+ }
97
+
98
+ if ($currentServer -eq $targetServer) {
99
+ Write-Host "[OK] Server 配置正确: $targetServer"
100
+ } else {
101
+ $currentDisplay = if ($currentServer) { $currentServer } else { "未设置" }
102
+ Write-Host "[提示] 当前 server: $currentDisplay, 目标: $targetServer"
103
+ Write-Host "[执行] 正在设置 server 配置..."
104
+
105
+ node -e "
106
+ const fs = require('fs');
107
+ const path = require('path');
108
+ const configPath = path.join(require('os').homedir(), '.tt-help.json');
109
+ let cfg = {};
110
+ try { cfg = JSON.parse(fs.readFileSync(configPath, 'utf-8')); } catch(e) {}
111
+ cfg.server = '$targetServer';
112
+ fs.writeFileSync(configPath, JSON.stringify(cfg, null, 2), 'utf-8');
113
+ console.log(' 已写入: ' + configPath);
114
+ "
115
+ Write-Host "[OK] Server 配置已设置"
116
+ }
117
+
118
+ # ---------- 3. 询问用户参数 ----------
119
+ Write-Host ""
120
+ Write-Host "========================================"
121
+ Write-Host " 参数配置"
122
+ Write-Host "========================================"
123
+
124
+ $inputBasePort = Read-Host "起始端口 (--base-port) [默认: 9222]"
125
+ $basePort = if ($inputBasePort) { $inputBasePort } else { "9222" }
126
+
127
+ $inputPortCount = Read-Host "端口数量 (--port-count) [默认: 10]"
128
+ $portCount = if ($inputPortCount) { $inputPortCount } else { "10" }
129
+
130
+ $inputJobLocations = Read-Host "任务国家 (--job-locations) [默认: 无,使用全部]"
131
+ $jobLocationsArg = if ($inputJobLocations) { "--job-locations $inputJobLocations" } else { "" }
132
+
133
+ # ---------- 4. 获取配置中的用户编号并拼接 ----------
134
+ $configUserId = ""
135
+ if (Test-Path $configPath) {
136
+ try {
137
+ $config = Get-Content $configPath -Raw | ConvertFrom-Json
138
+ $configUserId = $config.userId
139
+ } catch {
140
+ $configUserId = ""
141
+ }
142
+ }
143
+ if (-not $configUserId) { $configUserId = "user" }
144
+ $userId = "${configUserId}_${basePort}_${portCount}"
145
+
146
+ # ---------- 5. 启动 tt-help explore ----------
147
+ Write-Host ""
148
+ Write-Host "========================================"
149
+ Write-Host " 启动 tt-help explore"
150
+ Write-Host "========================================"
151
+ Write-Host " 用户编号: $userId"
152
+ Write-Host " 起始端口: $basePort"
153
+ Write-Host " 端口数量: $portCount"
154
+ if ($inputJobLocations) { Write-Host " 任务国家: $inputJobLocations" }
155
+ Write-Host " 最大关注: 5"
156
+ Write-Host " 最大粉丝: 5"
157
+ Write-Host " 速度: stealth (最慢)"
158
+ Write-Host "========================================"
159
+ tt-help explore stealth --user-id $userId --base-port $basePort --port-count $portCount --max-following 5 --max-followers 5 $jobLocationsArg