tt-help-cli-ycl 1.3.34 → 1.3.35
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 +17 -17
- package/cli.js +9 -9
- package/package.json +47 -47
- package/scripts/run-explore copy.bat +101 -101
- package/scripts/run-explore.bat +132 -132
- package/scripts/run-explore.ps1 +157 -157
- package/scripts/run-explore.sh +119 -119
- 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/src/cli/attach.js +180 -180
- package/src/cli/auto.js +240 -240
- package/src/cli/config.js +152 -152
- package/src/cli/explore.js +488 -488
- package/src/cli/info.js +88 -88
- package/src/cli/open.js +111 -111
- package/src/cli/progress.js +111 -111
- package/src/cli/refresh.js +216 -216
- package/src/cli/scrape.js +47 -47
- package/src/cli/utils.js +18 -18
- package/src/cli/videos.js +41 -41
- package/src/cli/watch.js +31 -31
- package/src/lib/args.js +722 -722
- 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 +183 -183
- package/src/lib/constants.js +216 -216
- 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 +105 -105
- 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 +89 -89
- package/src/lib/tiktok-scraper.mjs +194 -194
- package/src/lib/url.js +52 -52
- package/src/main.js +48 -48
- 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 +211 -211
- package/src/scraper/explore-core.js +177 -167
- package/src/scraper/modules/captcha-handler.js +114 -114
- package/src/scraper/modules/follow-extractor.js +194 -194
- package/src/scraper/modules/guess-extractor.js +51 -51
- package/src/scraper/modules/page-helpers.js +48 -48
- package/src/scraper/refresh-core.js +179 -179
- package/src/videos/core.js +125 -125
- package/src/watch/data-store.js +1040 -1030
- package/src/watch/public/index.html +1458 -753
- package/src/watch/server.js +939 -933
package/README.md
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
# tt-help
|
|
2
|
-
|
|
3
|
-
TikTok user & video data scraper — extract ttSeller, verified, locationCreated from HTML source.
|
|
4
|
-
|
|
5
|
-
## Install
|
|
6
|
-
|
|
7
|
-
```bash
|
|
8
|
-
npm i -g tt-help
|
|
9
|
-
```
|
|
10
|
-
|
|
11
|
-
## Usage
|
|
12
|
-
|
|
13
|
-
```bash
|
|
14
|
-
tt-help [options] <urls...>
|
|
15
|
-
```
|
|
16
|
-
|
|
17
|
-
示例、代理配置、和更多用法请查看仓库或 `src/main.mjs` 中的帮助文本。
|
|
1
|
+
# tt-help
|
|
2
|
+
|
|
3
|
+
TikTok user & video data scraper — extract ttSeller, verified, locationCreated from HTML source.
|
|
4
|
+
|
|
5
|
+
## Install
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm i -g tt-help
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Usage
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
tt-help [options] <urls...>
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
示例、代理配置、和更多用法请查看仓库或 `src/main.mjs` 中的帮助文本。
|
package/cli.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import { fileURLToPath } from 'url';
|
|
3
|
-
import { dirname, resolve } from 'path';
|
|
4
|
-
|
|
5
|
-
const __filename = fileURLToPath(import.meta.url);
|
|
6
|
-
const __dirname = dirname(__filename);
|
|
7
|
-
|
|
8
|
-
const mainPath = resolve(__dirname, 'src', 'main.js');
|
|
9
|
-
await import(`file://${mainPath}`);
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { fileURLToPath } from 'url';
|
|
3
|
+
import { dirname, resolve } from 'path';
|
|
4
|
+
|
|
5
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
6
|
+
const __dirname = dirname(__filename);
|
|
7
|
+
|
|
8
|
+
const mainPath = resolve(__dirname, 'src', 'main.js');
|
|
9
|
+
await import(`file://${mainPath}`);
|
package/package.json
CHANGED
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "tt-help-cli-ycl",
|
|
3
|
-
"version": "1.3.
|
|
4
|
-
"description": "TikTok user & video data scraper - extract ttSeller, verified, locationCreated from HTML source",
|
|
5
|
-
"type": "module",
|
|
6
|
-
"bin": {
|
|
7
|
-
"tt-help": "cli.js"
|
|
8
|
-
},
|
|
9
|
-
"main": "src/main.js",
|
|
10
|
-
"files": [
|
|
11
|
-
"cli.js",
|
|
12
|
-
"src/",
|
|
13
|
-
"scripts/"
|
|
14
|
-
],
|
|
15
|
-
"scripts": {
|
|
16
|
-
"start": "node src/main.js"
|
|
17
|
-
},
|
|
18
|
-
"keywords": [
|
|
19
|
-
"tiktok",
|
|
20
|
-
"scraper",
|
|
21
|
-
"cli",
|
|
22
|
-
"seller",
|
|
23
|
-
"ttSeller"
|
|
24
|
-
],
|
|
25
|
-
"author": "jsjhycl",
|
|
26
|
-
"license": "ISC",
|
|
27
|
-
"engines": {
|
|
28
|
-
"node": ">=18"
|
|
29
|
-
},
|
|
30
|
-
"publishConfig": {
|
|
31
|
-
"access": "public"
|
|
32
|
-
},
|
|
33
|
-
"repository": {
|
|
34
|
-
"type": "git",
|
|
35
|
-
"url": "git+https://github.com/jsjhycl/tt-help-cli.git"
|
|
36
|
-
},
|
|
37
|
-
"bugs": {
|
|
38
|
-
"url": "https://github.com/jsjhycl/tt-help-cli/issues"
|
|
39
|
-
},
|
|
40
|
-
"homepage": "https://github.com/jsjhycl/tt-help-cli#readme",
|
|
41
|
-
"dependencies": {
|
|
42
|
-
"axios": "^1.16.1",
|
|
43
|
-
"https-proxy-agent": "^9.0.0",
|
|
44
|
-
"playwright": "^1.59.1",
|
|
45
|
-
"undici": "^8.1.0"
|
|
46
|
-
}
|
|
47
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "tt-help-cli-ycl",
|
|
3
|
+
"version": "1.3.35",
|
|
4
|
+
"description": "TikTok user & video data scraper - extract ttSeller, verified, locationCreated from HTML source",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"bin": {
|
|
7
|
+
"tt-help": "cli.js"
|
|
8
|
+
},
|
|
9
|
+
"main": "src/main.js",
|
|
10
|
+
"files": [
|
|
11
|
+
"cli.js",
|
|
12
|
+
"src/",
|
|
13
|
+
"scripts/"
|
|
14
|
+
],
|
|
15
|
+
"scripts": {
|
|
16
|
+
"start": "node src/main.js"
|
|
17
|
+
},
|
|
18
|
+
"keywords": [
|
|
19
|
+
"tiktok",
|
|
20
|
+
"scraper",
|
|
21
|
+
"cli",
|
|
22
|
+
"seller",
|
|
23
|
+
"ttSeller"
|
|
24
|
+
],
|
|
25
|
+
"author": "jsjhycl",
|
|
26
|
+
"license": "ISC",
|
|
27
|
+
"engines": {
|
|
28
|
+
"node": ">=18"
|
|
29
|
+
},
|
|
30
|
+
"publishConfig": {
|
|
31
|
+
"access": "public"
|
|
32
|
+
},
|
|
33
|
+
"repository": {
|
|
34
|
+
"type": "git",
|
|
35
|
+
"url": "git+https://github.com/jsjhycl/tt-help-cli.git"
|
|
36
|
+
},
|
|
37
|
+
"bugs": {
|
|
38
|
+
"url": "https://github.com/jsjhycl/tt-help-cli/issues"
|
|
39
|
+
},
|
|
40
|
+
"homepage": "https://github.com/jsjhycl/tt-help-cli#readme",
|
|
41
|
+
"dependencies": {
|
|
42
|
+
"axios": "^1.16.1",
|
|
43
|
+
"https-proxy-agent": "^9.0.0",
|
|
44
|
+
"playwright": "^1.59.1",
|
|
45
|
+
"undici": "^8.1.0"
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -1,101 +1,101 @@
|
|
|
1
|
-
@ECHO OFF
|
|
2
|
-
SETLOCAL EnableDelayedExpansion
|
|
3
|
-
|
|
4
|
-
SET "PACKAGENAME=tt-help-cli-ycl"
|
|
5
|
-
SET "TARGET_SERVER=http://117.71.53.99:17301"
|
|
6
|
-
SET "LOCAL_IP="
|
|
7
|
-
SET "GET_IP_PS1=%TEMP%\tt_get_local_ip.ps1"
|
|
8
|
-
>"%GET_IP_PS1%" ECHO $ip = $null
|
|
9
|
-
>>"%GET_IP_PS1%" ECHO try {
|
|
10
|
-
>>"%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
|
|
11
|
-
>>"%GET_IP_PS1%" ECHO } catch {}
|
|
12
|
-
>>"%GET_IP_PS1%" ECHO if (-not $ip) {
|
|
13
|
-
>>"%GET_IP_PS1%" ECHO try {
|
|
14
|
-
>>"%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
|
|
15
|
-
>>"%GET_IP_PS1%" ECHO } catch {}
|
|
16
|
-
>>"%GET_IP_PS1%" ECHO }
|
|
17
|
-
>>"%GET_IP_PS1%" ECHO if (-not $ip) {
|
|
18
|
-
>>"%GET_IP_PS1%" ECHO try {
|
|
19
|
-
>>"%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
|
|
20
|
-
>>"%GET_IP_PS1%" ECHO } catch {}
|
|
21
|
-
>>"%GET_IP_PS1%" ECHO }
|
|
22
|
-
>>"%GET_IP_PS1%" ECHO if ($ip) { [Console]::Write($ip) }
|
|
23
|
-
FOR /F "usebackq delims=" %%I IN (`powershell -NoProfile -ExecutionPolicy Bypass -File "%GET_IP_PS1%"`) DO (
|
|
24
|
-
SET "LOCAL_IP=%%I"
|
|
25
|
-
)
|
|
26
|
-
|
|
27
|
-
ECHO [INFO] Local IP: %LOCAL_IP%
|
|
28
|
-
|
|
29
|
-
IF DEFINED LOCAL_IP IF "%LOCAL_IP:~0,11%"=="172.18.154." SET "TARGET_SERVER=http://172.18.154.201:3001"
|
|
30
|
-
|
|
31
|
-
IF NOT DEFINED LOCAL_IP (
|
|
32
|
-
ECHO [INFO] No local IPv4 detected, using public server
|
|
33
|
-
) ELSE IF "%LOCAL_IP:~0,11%"=="172.18.154." (
|
|
34
|
-
ECHO [INFO] Intranet IP detected, using intranet server
|
|
35
|
-
) ELSE (
|
|
36
|
-
ECHO [INFO] No intranet IP detected, using public server
|
|
37
|
-
)
|
|
38
|
-
SET "CONFIG_PATH=%USERPROFILE%\.tt-help.json"
|
|
39
|
-
|
|
40
|
-
ECHO ========================================
|
|
41
|
-
ECHO tt-help-cli-ycl one-click launcher (Windows CMD)
|
|
42
|
-
ECHO ========================================
|
|
43
|
-
|
|
44
|
-
REM ---------- 1. Check/install latest version ----------
|
|
45
|
-
FOR /F "delims=" %%V IN ('npm view %PACKAGENAME% version 2^>nul') DO SET "LATEST_VERSION=%%V"
|
|
46
|
-
|
|
47
|
-
IF NOT DEFINED LATEST_VERSION (
|
|
48
|
-
ECHO [ERROR] Cannot get latest version from npm
|
|
49
|
-
EXIT /B 1
|
|
50
|
-
)
|
|
51
|
-
|
|
52
|
-
FOR /F "tokens=2 delims=@" %%V IN ('npm list -g %PACKAGENAME% --depth=0 2^>nul ^| findstr /i "%PACKAGENAME%"') DO SET "INSTALLED_VERSION=%%V"
|
|
53
|
-
|
|
54
|
-
IF NOT DEFINED INSTALLED_VERSION (
|
|
55
|
-
ECHO [INFO] %PACKAGENAME% not installed, installing latest...
|
|
56
|
-
CALL npm install -g %PACKAGENAME%
|
|
57
|
-
IF %ERRORLEVEL% EQU 0 (
|
|
58
|
-
ECHO [OK] Installed: %LATEST_VERSION%
|
|
59
|
-
) ELSE (
|
|
60
|
-
ECHO [ERROR] Install failed, run manually: npm install -g %PACKAGENAME%
|
|
61
|
-
EXIT /B 1
|
|
62
|
-
)
|
|
63
|
-
) ELSE IF "%INSTALLED_VERSION%"=="%LATEST_VERSION%" (
|
|
64
|
-
ECHO [OK] %PACKAGENAME% is up to date: %LATEST_VERSION%
|
|
65
|
-
) ELSE (
|
|
66
|
-
ECHO [INFO] Current: %INSTALLED_VERSION%, Latest: %LATEST_VERSION%
|
|
67
|
-
ECHO [INFO] Upgrading to latest...
|
|
68
|
-
CALL npm install -g %PACKAGENAME%
|
|
69
|
-
IF %ERRORLEVEL% EQU 0 (
|
|
70
|
-
ECHO [OK] Upgraded: %LATEST_VERSION%
|
|
71
|
-
) ELSE (
|
|
72
|
-
ECHO [WARN] Upgrade failed, run manually: npm install -g %PACKAGENAME%
|
|
73
|
-
)
|
|
74
|
-
)
|
|
75
|
-
|
|
76
|
-
REM ---------- 2. Check/set server config ----------
|
|
77
|
-
SET "CURRENT_SERVER="
|
|
78
|
-
IF EXIST "%CONFIG_PATH%" (
|
|
79
|
-
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"
|
|
80
|
-
)
|
|
81
|
-
|
|
82
|
-
IF "%CURRENT_SERVER%"=="%TARGET_SERVER%" (
|
|
83
|
-
ECHO [OK] Server config is correct: %TARGET_SERVER%
|
|
84
|
-
) ELSE (
|
|
85
|
-
IF "%CURRENT_SERVER%"=="" (
|
|
86
|
-
ECHO [INFO] Current server: not set, target: %TARGET_SERVER%
|
|
87
|
-
) ELSE (
|
|
88
|
-
ECHO [INFO] Current server: %CURRENT_SERVER%, target: %TARGET_SERVER%
|
|
89
|
-
)
|
|
90
|
-
ECHO [INFO] Setting server config...
|
|
91
|
-
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);"
|
|
92
|
-
ECHO [OK] Server config set
|
|
93
|
-
)
|
|
94
|
-
|
|
95
|
-
REM ---------- 3. Start tt-help explore ----------
|
|
96
|
-
ECHO.
|
|
97
|
-
ECHO ========================================
|
|
98
|
-
ECHO Starting tt-help explore
|
|
99
|
-
ECHO ========================================
|
|
100
|
-
tt-help explore --port 9223 --profile p9223
|
|
101
|
-
DEL "%GET_IP_PS1%" 2>NUL
|
|
1
|
+
@ECHO OFF
|
|
2
|
+
SETLOCAL EnableDelayedExpansion
|
|
3
|
+
|
|
4
|
+
SET "PACKAGENAME=tt-help-cli-ycl"
|
|
5
|
+
SET "TARGET_SERVER=http://117.71.53.99:17301"
|
|
6
|
+
SET "LOCAL_IP="
|
|
7
|
+
SET "GET_IP_PS1=%TEMP%\tt_get_local_ip.ps1"
|
|
8
|
+
>"%GET_IP_PS1%" ECHO $ip = $null
|
|
9
|
+
>>"%GET_IP_PS1%" ECHO try {
|
|
10
|
+
>>"%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
|
|
11
|
+
>>"%GET_IP_PS1%" ECHO } catch {}
|
|
12
|
+
>>"%GET_IP_PS1%" ECHO if (-not $ip) {
|
|
13
|
+
>>"%GET_IP_PS1%" ECHO try {
|
|
14
|
+
>>"%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
|
|
15
|
+
>>"%GET_IP_PS1%" ECHO } catch {}
|
|
16
|
+
>>"%GET_IP_PS1%" ECHO }
|
|
17
|
+
>>"%GET_IP_PS1%" ECHO if (-not $ip) {
|
|
18
|
+
>>"%GET_IP_PS1%" ECHO try {
|
|
19
|
+
>>"%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
|
|
20
|
+
>>"%GET_IP_PS1%" ECHO } catch {}
|
|
21
|
+
>>"%GET_IP_PS1%" ECHO }
|
|
22
|
+
>>"%GET_IP_PS1%" ECHO if ($ip) { [Console]::Write($ip) }
|
|
23
|
+
FOR /F "usebackq delims=" %%I IN (`powershell -NoProfile -ExecutionPolicy Bypass -File "%GET_IP_PS1%"`) DO (
|
|
24
|
+
SET "LOCAL_IP=%%I"
|
|
25
|
+
)
|
|
26
|
+
|
|
27
|
+
ECHO [INFO] Local IP: %LOCAL_IP%
|
|
28
|
+
|
|
29
|
+
IF DEFINED LOCAL_IP IF "%LOCAL_IP:~0,11%"=="172.18.154." SET "TARGET_SERVER=http://172.18.154.201:3001"
|
|
30
|
+
|
|
31
|
+
IF NOT DEFINED LOCAL_IP (
|
|
32
|
+
ECHO [INFO] No local IPv4 detected, using public server
|
|
33
|
+
) ELSE IF "%LOCAL_IP:~0,11%"=="172.18.154." (
|
|
34
|
+
ECHO [INFO] Intranet IP detected, using intranet server
|
|
35
|
+
) ELSE (
|
|
36
|
+
ECHO [INFO] No intranet IP detected, using public server
|
|
37
|
+
)
|
|
38
|
+
SET "CONFIG_PATH=%USERPROFILE%\.tt-help.json"
|
|
39
|
+
|
|
40
|
+
ECHO ========================================
|
|
41
|
+
ECHO tt-help-cli-ycl one-click launcher (Windows CMD)
|
|
42
|
+
ECHO ========================================
|
|
43
|
+
|
|
44
|
+
REM ---------- 1. Check/install latest version ----------
|
|
45
|
+
FOR /F "delims=" %%V IN ('npm view %PACKAGENAME% version 2^>nul') DO SET "LATEST_VERSION=%%V"
|
|
46
|
+
|
|
47
|
+
IF NOT DEFINED LATEST_VERSION (
|
|
48
|
+
ECHO [ERROR] Cannot get latest version from npm
|
|
49
|
+
EXIT /B 1
|
|
50
|
+
)
|
|
51
|
+
|
|
52
|
+
FOR /F "tokens=2 delims=@" %%V IN ('npm list -g %PACKAGENAME% --depth=0 2^>nul ^| findstr /i "%PACKAGENAME%"') DO SET "INSTALLED_VERSION=%%V"
|
|
53
|
+
|
|
54
|
+
IF NOT DEFINED INSTALLED_VERSION (
|
|
55
|
+
ECHO [INFO] %PACKAGENAME% not installed, installing latest...
|
|
56
|
+
CALL npm install -g %PACKAGENAME%
|
|
57
|
+
IF %ERRORLEVEL% EQU 0 (
|
|
58
|
+
ECHO [OK] Installed: %LATEST_VERSION%
|
|
59
|
+
) ELSE (
|
|
60
|
+
ECHO [ERROR] Install failed, run manually: npm install -g %PACKAGENAME%
|
|
61
|
+
EXIT /B 1
|
|
62
|
+
)
|
|
63
|
+
) ELSE IF "%INSTALLED_VERSION%"=="%LATEST_VERSION%" (
|
|
64
|
+
ECHO [OK] %PACKAGENAME% is up to date: %LATEST_VERSION%
|
|
65
|
+
) ELSE (
|
|
66
|
+
ECHO [INFO] Current: %INSTALLED_VERSION%, Latest: %LATEST_VERSION%
|
|
67
|
+
ECHO [INFO] Upgrading to latest...
|
|
68
|
+
CALL npm install -g %PACKAGENAME%
|
|
69
|
+
IF %ERRORLEVEL% EQU 0 (
|
|
70
|
+
ECHO [OK] Upgraded: %LATEST_VERSION%
|
|
71
|
+
) ELSE (
|
|
72
|
+
ECHO [WARN] Upgrade failed, run manually: npm install -g %PACKAGENAME%
|
|
73
|
+
)
|
|
74
|
+
)
|
|
75
|
+
|
|
76
|
+
REM ---------- 2. Check/set server config ----------
|
|
77
|
+
SET "CURRENT_SERVER="
|
|
78
|
+
IF EXIST "%CONFIG_PATH%" (
|
|
79
|
+
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"
|
|
80
|
+
)
|
|
81
|
+
|
|
82
|
+
IF "%CURRENT_SERVER%"=="%TARGET_SERVER%" (
|
|
83
|
+
ECHO [OK] Server config is correct: %TARGET_SERVER%
|
|
84
|
+
) ELSE (
|
|
85
|
+
IF "%CURRENT_SERVER%"=="" (
|
|
86
|
+
ECHO [INFO] Current server: not set, target: %TARGET_SERVER%
|
|
87
|
+
) ELSE (
|
|
88
|
+
ECHO [INFO] Current server: %CURRENT_SERVER%, target: %TARGET_SERVER%
|
|
89
|
+
)
|
|
90
|
+
ECHO [INFO] Setting server config...
|
|
91
|
+
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);"
|
|
92
|
+
ECHO [OK] Server config set
|
|
93
|
+
)
|
|
94
|
+
|
|
95
|
+
REM ---------- 3. Start tt-help explore ----------
|
|
96
|
+
ECHO.
|
|
97
|
+
ECHO ========================================
|
|
98
|
+
ECHO Starting tt-help explore
|
|
99
|
+
ECHO ========================================
|
|
100
|
+
tt-help explore --port 9223 --profile p9223
|
|
101
|
+
DEL "%GET_IP_PS1%" 2>NUL
|
package/scripts/run-explore.bat
CHANGED
|
@@ -1,132 +1,132 @@
|
|
|
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 Speed: stealth (slowest)
|
|
131
|
-
ECHO ========================================
|
|
132
|
-
CALL tt-help explore stealth --user-id %%USER_ID%% --base-port %%BASE_PORT%% --port-count %%PORT_COUNT%% %%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 Speed: stealth (slowest)
|
|
131
|
+
ECHO ========================================
|
|
132
|
+
CALL tt-help explore stealth --user-id %%USER_ID%% --base-port %%BASE_PORT%% --port-count %%PORT_COUNT%% %%JOB_LOC_ARGS%%
|