tt-help-cli-ycl 1.3.48 → 1.3.50
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.
- package/README.md +33 -33
- package/cli.js +9 -9
- package/package.json +52 -52
- package/scripts/run-explore copy.bat +101 -101
- package/scripts/run-explore.bat +134 -134
- package/scripts/run-explore.ps1 +159 -159
- package/scripts/run-explore.sh +121 -121
- package/scripts/test-captcha-lib.mjs +68 -0
- package/scripts/test-captcha.mjs +81 -0
- package/scripts/test-incognito-lib.mjs +36 -0
- package/scripts/test-login-state.mjs +128 -0
- package/scripts/test-safe-click.mjs +45 -0
- package/scripts/test-watch-db-smoke.mjs +246 -0
- package/src/cli/attach.js +331 -331
- package/src/cli/auto.js +265 -265
- package/src/cli/comments.js +620 -620
- package/src/cli/config.js +170 -170
- package/src/cli/db-import.js +51 -51
- package/src/cli/explore.js +555 -555
- package/src/cli/open.js +109 -111
- package/src/cli/progress.js +111 -111
- package/src/cli/refresh.js +288 -288
- package/src/cli/scrape.js +47 -47
- package/src/cli/utils.js +18 -18
- package/src/cli/videos.js +41 -41
- package/src/cli/videostats.js +196 -196
- package/src/cli/watch.js +30 -30
- package/src/lib/api-interceptor.js +161 -161
- package/src/lib/args.js +809 -809
- package/src/lib/browser/anti-detect.js +23 -23
- package/src/lib/browser/cdp.js +261 -261
- package/src/lib/browser/health-checker.js +114 -114
- package/src/lib/browser/launch.js +43 -43
- package/src/lib/browser/page.js +184 -184
- package/src/lib/constants.js +297 -297
- package/src/lib/delay.js +54 -54
- package/src/lib/explore-fetch.js +118 -118
- package/src/lib/fetcher.js +45 -45
- package/src/lib/filter.js +66 -66
- package/src/lib/io.js +54 -54
- package/src/lib/output.js +80 -80
- package/src/lib/page-error-detector.js +109 -109
- package/src/lib/parse-ssr.mjs +69 -69
- package/src/lib/parser.js +47 -47
- package/src/lib/retry.js +45 -45
- package/src/lib/scrape.js +90 -90
- package/src/lib/target-locations.js +61 -61
- package/src/lib/tiktok-scraper.mjs +98 -61
- package/src/lib/url.js +52 -52
- package/src/main.js +73 -73
- package/src/npm-main.js +70 -70
- package/src/results/user-videos-bar.lar.lar.moeta.json +37 -0
- package/src/scraper/auto-core.js +203 -203
- package/src/scraper/core.js +255 -255
- package/src/scraper/explore-core.js +208 -208
- package/src/scraper/modules/captcha-handler.js +114 -114
- package/src/scraper/modules/follow-extractor.js +250 -250
- package/src/scraper/modules/guess-extractor.js +51 -51
- package/src/scraper/modules/page-helpers.js +48 -48
- package/src/scraper/refresh-core.js +213 -213
- package/src/videos/core.js +143 -143
- package/src/watch/data-store.js +2980 -2980
- package/src/watch/public/index.html +2355 -2355
- package/src/watch/server.js +727 -727
package/scripts/run-explore.bat
CHANGED
|
@@ -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%%
|
package/scripts/run-explore.ps1
CHANGED
|
@@ -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
|