@mindexec/cli
v0.2.219
Published
MindExec local runtime and bridge CLI
Maintainers
Readme
MindExec Local Bridge Server
??Blazor ?깆뿉??濡쒖뺄 ?뚯씪 ?쒖뒪?쒖뿉 ?묎렐?섍린 ?꾪븳 Node.js 釉뚮━吏 ?쒕쾭?낅땲??
npm quick start
npx @mindexec/cliThe npm CLI now starts both pieces of the local product:
- MindCanvas app:
http://localhost:5147/mindcanvas - LocalBridge API:
http://127.0.0.1:5147/api/status - Workspace assets:
http://127.0.0.1:5147/assets/...
By default the CLI opens the MindCanvas app in your default browser after the
bridge is ready. Use mindexec --no-open or MINDEXEC_NO_OPEN=1 when you only
want to start the listener.
For npx and global installs, the default workspace is the directory where you
run the command. Run it from the folder that contains your .mindexec data, or
pass the workspace explicitly:
npx @mindexec/cli --workspace /path/to/workspaceFor local frontend development, keep LocalBridge running and refresh the packaged app bundle after code changes:
.\scripts\publish-mindexec-cli.ps1 -AppOnlyThen hard-refresh http://localhost:5147/mindcanvas in the browser.
The app and bridge are packaged together. Run scripts/publish-mindexec-cli.ps1
from the repository root before publishing so the latest
MindExecution.Web WASM wwwroot is copied into LocalBridge/wwwroot.
The packaged app is configured with Bridge:Url=app-origin, so custom
BRIDGE_PORT values keep the WASM app and LocalBridge API on the same origin.
The publish helper trims hosted/demo-only gallery images and unused
precompressed static files from the npm bundle by default. Use
-KeepPackagedGalleryImages or -KeepPackagedPrecompressedAssets only when
testing a full untrimmed local package.
Remote Direct quick start
LocalBridge also starts a separate RemoteHub listener for direct remote-agent experiments. By default it binds to loopback only:
npx @mindexec/cli
npx @mindexec/remote connect --manager 127.0.0.1:5197 --pair <pair-token>Read the pair token from the protected local endpoint:
curl -H "X-Bridge-Token: <bridge-token>" http://127.0.0.1:5147/api/remote/statusLAN/direct mode must be enabled explicitly by changing the RemoteHub bind host:
$env:REMOTE_HUB_HOST="0.0.0.0"
$env:REMOTE_HUB_PORT="5197"
$env:REMOTE_HUB_PAIR_TOKEN="<strong-token>"
npx @mindexec/cliDevice inventory is intentionally not paginated:
curl -H "X-Bridge-Token: <bridge-token>" http://127.0.0.1:5147/api/remote/devicesRequest and read the latest view-only thumbnail for a connected device:
curl -X POST -H "X-Bridge-Token: <bridge-token>" http://127.0.0.1:5147/api/remote/devices/<device-id>/thumbnail/request
curl -H "X-Bridge-Token: <bridge-token>" http://127.0.0.1:5147/api/remote/devices/<device-id>/thumbnailStart, read, and stop the focused view-only RemoteFast live stream:
curl -X POST -H "X-Bridge-Token: <bridge-token>" -H "Content-Type: application/json" \
-d "{\"fps\":12,\"maxWidth\":960,\"maxHeight\":540,\"quality\":60}" \
http://127.0.0.1:5147/api/remote/devices/<device-id>/live/start
curl -H "X-Bridge-Token: <bridge-token>" http://127.0.0.1:5147/api/remote/devices/<device-id>/live/frame
curl -X POST -H "X-Bridge-Token: <bridge-token>" http://127.0.0.1:5147/api/remote/devices/<device-id>/live/stopQueue a safe task-only instruction for one device or all connected devices:
curl -X POST -H "X-Bridge-Token: <bridge-token>" -H "Content-Type: application/json" \
-d "{\"instruction\":\"Check the desktop and report status.\"}" \
http://127.0.0.1:5147/api/remote/devices/<device-id>/tasks
curl -X POST -H "X-Bridge-Token: <bridge-token>" -H "Content-Type: application/json" \
-d "{\"instruction\":\"Prepare a short status report.\",\"allConnected\":true}" \
http://127.0.0.1:5147/api/remote/tasksQueue an opt-in text-only AI assist task for agents started with --ai:
curl -X POST -H "X-Bridge-Token: <bridge-token>" -H "Content-Type: application/json" \
-d "{\"instruction\":\"Summarize what this computer should do next.\",\"allConnected\":true,\"approvalLevel\":\"ai-assist\"}" \
http://127.0.0.1:5147/api/remote/tasks?먮뒗 ?꾩뿭 ?ㅼ튂 ???ㅽ뻾?⑸땲??
npm install -g @mindexec/cli
mindexec湲곕낯 ?ㅽ뻾 二쇱냼??http://127.0.0.1:5147?낅땲?? WORKSPACE_PATH媛 鍮꾩뼱 ?덉쑝硫??ㅼ튂???⑦궎吏??遺紐??대뜑瑜?湲곕낯 ?묒뾽 怨듦컙?쇰줈 ?ъ슜?⑸땲??
mindexec --workspace /custom/path
BRIDGE_PORT=8080 WORKSPACE_PATH=/custom/path mindexec?꾩?留먭낵 踰꾩쟾 ?뺤씤:
mindexec --help
mindexec --version?ㅼ튂
cd LocalBridge
npm install?ㅽ뻾
?쇰컲 ?ㅽ뻾
cd LocalBridge
npm startnpm start??WORKSPACE_PATH媛 鍮꾩뼱 ?덉쑝硫?LocalBridge??遺紐??대뜑(蹂댄넻 ??μ냼 猷⑦듃)瑜?湲곕낯 ?묒뾽 怨듦컙?쇰줈 ?ъ슜?⑸땲??
macOS / Linux?먯꽌 ?명븯寃??ㅽ뻾
cd LocalBridge
chmod +x start-bridge.sh
./start-bridge.shstart-bridge.sh???ㅼ쓬???먮룞?쇰줈 泥섎━?⑸땲??
WORKSPACE_PATH媛 ?놁쑝硫???μ냼 猷⑦듃瑜??묒뾽 怨듦컙?쇰줈 ?ъ슜BRIDGE_PORT媛 ?놁쑝硫?5147?ъ슜- 媛숈? ?ы듃???대? 釉뚮━吏媛 ???덉쑝硫?以묐났 ?ㅽ뻾 諛⑹?
- ?ㅻⅨ OS?먯꽌 蹂듭궗????
node_modules媛 媛먯??섎㈃ ?꾩옱 ?뚮옯?쇱슜?쇰줈 ?ㅼ떆npm install
媛쒕컻 紐⑤뱶 (?먮룞 ?ъ떆??
npm run dev?섍꼍 蹂??
| 蹂??| ?ㅻ챸 | 湲곕낯媛?|
|------|------|--------|
| BRIDGE_PORT | ?쒕쾭 ?ы듃 | 5147 |
| WORKSPACE_PATH | ?묒뾽 怨듦컙 寃쎈줈 | LocalBridge ?먮뒗 ?ㅼ튂 ?⑦궎吏??遺紐??대뜑 (?놁쑝硫?~/Documents/MindExecution) |
| BRIDGE_TOKEN | ?꾪뿕 REST API???ъ슜??怨좎젙 ?좏겙. 鍮꾩슦硫??ㅽ뻾 ???쒕뜡 ?앹꽦 | ?쒕뜡 |
| BRIDGE_REQUIRE_TOKEN | false/0/off濡??ㅼ젙?섎㈃ REST ?좏겙 寃??鍮꾪솢?깊솕 | true |
| COMPANY_CORE_URL | CompanyCore 濡쒖뺄 API 二쇱냼. /api/company-core/* ?꾨줉?????| http://127.0.0.1:5077 |
| BRIDGE_SKIP_PORT_REAP | ?쒖옉 ???숈씪 ?ы듃??湲곗〈 MindExec bridge ?뺣━瑜?嫄대꼫?? | false |
| BRIDGE_FORCE_KILL_PORT_OWNER | BRIDGE_PORT瑜??≪쓣 ?꾩쓽 ?꾨줈?몄뒪瑜??뺣━ | false |
?덉떆:
BRIDGE_PORT=8080 WORKSPACE_PATH=/custom/path npm startmacOS / Linux?먯꽌 ?ㅽ겕由쏀듃? ?④퍡 ?ㅽ뻾???뚮룄 ?숈씪?⑸땲??
BRIDGE_PORT=8080 WORKSPACE_PATH=/custom/path ./start-bridge.shAPI ?붾뱶?ъ씤??
?곹깭 ?뺤씤
GET /api/status- ?쒕쾭 ?곹깭 ?뺤씤,/events??wsToken怨??꾪뿕 REST API??bridgeToken諛섑솚
?묒뾽 怨듦컙
GET /api/workspace- ?꾩옱 ?묒뾽 怨듦컙 ?뺣낫POST /api/workspace/set- ?묒뾽 怨듦컙 寃쎈줈 ?ㅼ젙
?뚯씪 ?묒뾽
POST /api/file/read- ?뚯씪 ?쎄린POST /api/file/write- ?뚯씪 ?곌린POST /api/file/delete- ?뚯씪 ??젣POST /api/file/exists- ?뚯씪 議댁옱 ?뺤씤POST /api/file/copy- ?뚯씪 蹂듭궗POST /api/file/move- ?뚯씪 ?대룞/?대쫫 蹂寃?POST /api/file/info- ?뚯씪 ?뺣낫
?붾젆?좊━ ?묒뾽
POST /api/dir/create- ?붾젆?좊━ ?앹꽦POST /api/dir/list- ?붾젆?좊━ 紐⑸줉POST /api/dir/delete- ?붾젆?좊━ ??젣
???ㅽ뻾
POST /api/shell/execute- ??紐낅졊 ?ㅽ뻾. 湲곗〈 ?명솚?⑹씠硫??대??곸쑝濡?job ?대깽?몃?/events濡??꾩넚POST /api/shell/jobs- ??紐낅졊??諛깃렇?쇱슫??job?쇰줈 ?쒖옉?섍퀬jobId諛섑솚GET /api/shell/jobs/:jobId- job ?곹깭/異쒕젰 議고쉶POST /api/shell/jobs/:jobId/cancel- ?ㅽ뻾 以묒씤 job 痍⑥냼
?대깽???ㅽ듃由?- WebSocket /events?token=<wsToken> - ?꾨줈?앺듃 蹂寃쎄낵 shell/Codex job ?대깽?몃? push
Shell/Codex job ?대깽??
ShellQueuedShellStartedShellStdoutShellStderrShellCompletedShellFailedShellCancelRequested
OpenAI Codex runtime
GET /api/codex/capabilities- TypeScript SDK / App Server scaffold / Legacy Exec provider availabilityPOST /api/codex/thread/start- start a local Codex threadPOST /api/codex/thread/run- run a Codex turn. Uses@openai/codex-sdkfirst and falls back to legacycodex execPOST /api/codex/thread/resume- resume a stored SDK thread by idPOST /api/codex/thread/cancel- cancel an active turnGET /api/codex/thread/:threadId/status- inspect local thread status and compact run metadata
The TypeScript SDK runs only inside LocalBridge. Browser/WASM clients should call these bridge endpoints and must not import or execute Codex SDK packages directly.
Port ownership
On startup, LocalBridge checks BRIDGE_PORT and stops an existing MindExec/LocalBridge listener on that same port before binding. If the port is owned by an unrelated process, startup fails with a clear message instead of silently killing it. Set BRIDGE_FORCE_KILL_PORT_OWNER=1 only when the launcher owns that port policy and should terminate any listener.
The start-bridge.bat and start-bridge.sh wrappers always delegate startup to launch-bridge.cjs, so port cleanup is handled by the same guard path on every launch.
CompanyCore ?꾨줉??- GET /api/company-core/health -> CompanyCore /health
GET /api/company-core/companies->CompanyCore /api/companiesPOST /api/company-core/companies/create-and-run->CompanyCore /api/companies/create-and-run
MindExec Web? CompanyCore ?ы듃瑜?吏곸젒 ???꾩슂 ?놁씠 LocalBridge 5147留??몄텧?섎㈃ ?⑸땲?? ???꾨줉?쒕룄 Bridge Token 蹂댄샇瑜?諛쏆뒿?덈떎.
蹂댁븞 二쇱쓽?ы빆
- ???쒕쾭??*濡쒖뺄?몄뒪??127.0.0.1)?먯꽌留? ?묎렐 媛?ν빀?덈떎.
- ?묒뾽 怨듦컙 ?몃????뚯씪?먮뒗 ?묎렐?????놁뒿?덈떎.
- ?꾪뿕????紐낅졊(rm -rf, format ??? 李⑤떒?⑸땲??
- ?뚯씪 ?곌린/??젣, ?붾젆?좊━ ?앹꽦/??젣, asset ?낅줈?? shell, project open/close 媛숈? ?꾪뿕 REST API??湲곕낯?곸쑝濡?
X-Bridge-Token?먮뒗Authorization: Bearer <token>???꾩슂?⑸땲?? - ?좏겙?
GET /api/status??bridgeToken?쇰줈 ?뺤씤?⑸땲?? 怨좎젙 ?좏겙???꾩슂?섎㈃BRIDGE_TOKEN?섍꼍 蹂?섎? ?ъ슜?섏꽭??
?ъ슜 ?덉떆
?뚯씪 ?쎄린
const response = await fetch('http://127.0.0.1:5147/api/file/read', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ path: 'test.txt' })
});
const data = await response.json();
console.log(data.content);?뚯씪 ?곌린
const status = await fetch('http://127.0.0.1:5147/api/status').then(r => r.json());
await fetch('http://127.0.0.1:5147/api/file/write', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
[status.bridgeTokenHeader || 'X-Bridge-Token']: status.bridgeToken
},
body: JSON.stringify({
path: 'test.txt',
content: 'Hello, World!'
})
});??紐낅졊 ?ㅽ뻾
const status = await fetch('http://127.0.0.1:5147/api/status').then(r => r.json());
const response = await fetch('http://127.0.0.1:5147/api/shell/execute', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
[status.bridgeTokenHeader || 'X-Bridge-Token']: status.bridgeToken
},
body: JSON.stringify({
command: 'dir',
timeout: 30000
})
});
const result = await response.json();
console.log(result.stdout);??job ?ㅽ듃由щ컢
const status = await fetch('http://127.0.0.1:5147/api/status').then(r => r.json());
const ws = new WebSocket(`ws://127.0.0.1:5147/events?token=${encodeURIComponent(status.wsToken)}`);
ws.onmessage = (message) => {
const event = JSON.parse(message.data);
if (event.type === 'ShellStdout') console.log(event.payload.chunk);
if (event.type === 'ShellCompleted') console.log('done', event.payload.jobId);
};
await fetch('http://127.0.0.1:5147/api/shell/jobs', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
[status.bridgeTokenHeader || 'X-Bridge-Token']: status.bridgeToken
},
body: JSON.stringify({
command: 'codex exec \"Summarize this repository\"',
timeout: 300000
})
});CORS
湲곕낯?곸쑝濡??ㅼ쓬 origin?ㅼ씠 ?덉슜?⑸땲??
- http://localhost:5000
- http://localhost:5001
- https://localhost:5001
- http://127.0.0.1:5000
- http://127.0.0.1:5001
異붽? origin???꾩슂?섎㈃ server.js??CORS ?ㅼ젙???섏젙?섏꽭??
Web怨?MAUI ?숈떆 ?ъ슜
- 釉뚮━吏 ?쒕쾭瑜??ㅽ뻾?⑸땲??(
npm start) - Web Blazor ?깆쓣 ?ㅽ뻾?⑸땲??
- MAUI ?깆? 釉뚮━吏 ?쒕쾭 ?놁씠???묐룞?⑸땲??(吏곸젒 ?뚯씪 ?쒖뒪???묎렐)
