atoo-studio 0.0.1 → 0.0.2
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/LICENSE +21 -0
- package/README.github.md +322 -0
- package/README.md +112 -0
- package/README.npm.md +112 -0
- package/bin/atoo-studio.js +90 -0
- package/dist/src/agents/claude-code-terminal/adapter.d.ts +42 -0
- package/dist/src/agents/claude-code-terminal/adapter.js +166 -0
- package/dist/src/agents/claude-code-terminal/index.d.ts +13 -0
- package/dist/src/agents/claude-code-terminal/index.js +45 -0
- package/dist/src/agents/claude-code-terminal/spawner.d.ts +9 -0
- package/dist/src/agents/claude-code-terminal/spawner.js +37 -0
- package/dist/src/agents/claude-code-terminal-chatro/adapter.d.ts +51 -0
- package/dist/src/agents/claude-code-terminal-chatro/adapter.js +301 -0
- package/dist/src/agents/claude-code-terminal-chatro/index.d.ts +13 -0
- package/dist/src/agents/claude-code-terminal-chatro/index.js +45 -0
- package/dist/src/agents/claude-code-terminal-chatro/jsonl-watcher.d.ts +67 -0
- package/dist/src/agents/claude-code-terminal-chatro/jsonl-watcher.js +431 -0
- package/dist/src/agents/claude-code-terminal-chatro/spawner.d.ts +9 -0
- package/dist/src/agents/claude-code-terminal-chatro/spawner.js +37 -0
- package/dist/src/agents/codex-terminal/adapter.d.ts +40 -0
- package/dist/src/agents/codex-terminal/adapter.js +160 -0
- package/dist/src/agents/codex-terminal/index.d.ts +13 -0
- package/dist/src/agents/codex-terminal/index.js +47 -0
- package/dist/src/agents/codex-terminal/spawner.d.ts +9 -0
- package/dist/src/agents/codex-terminal/spawner.js +56 -0
- package/dist/src/agents/codex-terminal-chatro/adapter.d.ts +58 -0
- package/dist/src/agents/codex-terminal-chatro/adapter.js +266 -0
- package/dist/src/agents/codex-terminal-chatro/index.d.ts +13 -0
- package/dist/src/agents/codex-terminal-chatro/index.js +50 -0
- package/dist/src/agents/codex-terminal-chatro/jsonl-watcher.d.ts +36 -0
- package/dist/src/agents/codex-terminal-chatro/jsonl-watcher.js +205 -0
- package/dist/src/agents/codex-terminal-chatro/spawner.d.ts +9 -0
- package/dist/src/agents/codex-terminal-chatro/spawner.js +57 -0
- package/dist/src/agents/lib/chain-builder.d.ts +21 -0
- package/dist/src/agents/lib/chain-builder.js +139 -0
- package/dist/src/agents/lib/claude/fs-sessions.d.ts +31 -0
- package/dist/src/agents/lib/claude/fs-sessions.js +329 -0
- package/dist/src/agents/lib/claude/jsonl-writer.d.ts +32 -0
- package/dist/src/agents/lib/claude/jsonl-writer.js +342 -0
- package/dist/src/agents/lib/claude/workspace-trust.d.ts +1 -0
- package/dist/src/agents/lib/claude/workspace-trust.js +29 -0
- package/dist/src/agents/lib/codex/fs-sessions.d.ts +34 -0
- package/dist/src/agents/lib/codex/fs-sessions.js +255 -0
- package/dist/src/agents/lib/codex/jsonl-mapper.d.ts +11 -0
- package/dist/src/agents/lib/codex/jsonl-mapper.js +154 -0
- package/dist/src/agents/lib/codex/jsonl-writer.d.ts +8 -0
- package/dist/src/agents/lib/codex/jsonl-writer.js +440 -0
- package/dist/src/agents/lib/fs-tracking.d.ts +36 -0
- package/dist/src/agents/lib/fs-tracking.js +109 -0
- package/dist/src/agents/lib/pty-activity-tracker.d.ts +37 -0
- package/dist/src/agents/lib/pty-activity-tracker.js +105 -0
- package/dist/src/agents/lib/session-id-utils.d.ts +46 -0
- package/dist/src/agents/lib/session-id-utils.js +147 -0
- package/dist/src/agents/lib/session-precreate.d.ts +17 -0
- package/dist/src/agents/lib/session-precreate.js +177 -0
- package/dist/src/agents/registry.d.ts +72 -0
- package/dist/src/agents/registry.js +337 -0
- package/dist/src/agents/types.d.ts +135 -0
- package/dist/src/agents/types.js +1 -0
- package/dist/src/auth/crypto-key.d.ts +6 -0
- package/dist/src/auth/crypto-key.js +45 -0
- package/dist/src/auth/middleware.d.ts +18 -0
- package/dist/src/auth/middleware.js +54 -0
- package/dist/src/auth/password.d.ts +2 -0
- package/dist/src/auth/password.js +12 -0
- package/dist/src/auth/session.d.ts +10 -0
- package/dist/src/auth/session.js +33 -0
- package/dist/src/auth/totp.d.ts +12 -0
- package/dist/src/auth/totp.js +61 -0
- package/dist/src/auth/webauthn.d.ts +6 -0
- package/dist/src/auth/webauthn.js +117 -0
- package/dist/src/config.d.ts +10 -0
- package/dist/src/config.js +16 -0
- package/dist/src/database/connection-manager.d.ts +25 -0
- package/dist/src/database/connection-manager.js +211 -0
- package/dist/src/database/discovery/container.d.ts +6 -0
- package/dist/src/database/discovery/container.js +226 -0
- package/dist/src/database/discovery/env-parser.d.ts +9 -0
- package/dist/src/database/discovery/env-parser.js +525 -0
- package/dist/src/database/discovery/local-files.d.ts +6 -0
- package/dist/src/database/discovery/local-files.js +58 -0
- package/dist/src/database/discovery/port-scan.d.ts +7 -0
- package/dist/src/database/discovery/port-scan.js +61 -0
- package/dist/src/database/drivers/cassandra.d.ts +12 -0
- package/dist/src/database/drivers/cassandra.js +91 -0
- package/dist/src/database/drivers/clickhouse.d.ts +11 -0
- package/dist/src/database/drivers/clickhouse.js +127 -0
- package/dist/src/database/drivers/elasticsearch.d.ts +12 -0
- package/dist/src/database/drivers/elasticsearch.js +169 -0
- package/dist/src/database/drivers/influxdb.d.ts +14 -0
- package/dist/src/database/drivers/influxdb.js +194 -0
- package/dist/src/database/drivers/memcached.d.ts +11 -0
- package/dist/src/database/drivers/memcached.js +117 -0
- package/dist/src/database/drivers/mongodb.d.ts +12 -0
- package/dist/src/database/drivers/mongodb.js +128 -0
- package/dist/src/database/drivers/mysql.d.ts +11 -0
- package/dist/src/database/drivers/mysql.js +112 -0
- package/dist/src/database/drivers/neo4j.d.ts +11 -0
- package/dist/src/database/drivers/neo4j.js +158 -0
- package/dist/src/database/drivers/postgresql.d.ts +11 -0
- package/dist/src/database/drivers/postgresql.js +133 -0
- package/dist/src/database/drivers/redis.d.ts +11 -0
- package/dist/src/database/drivers/redis.js +91 -0
- package/dist/src/database/drivers/sqlite.d.ts +10 -0
- package/dist/src/database/drivers/sqlite.js +100 -0
- package/dist/src/database/query-stream.d.ts +5 -0
- package/dist/src/database/query-stream.js +75 -0
- package/dist/src/database/types.d.ts +71 -0
- package/dist/src/database/types.js +1 -0
- package/dist/src/events/index.d.ts +3 -0
- package/dist/src/events/index.js +3 -0
- package/dist/src/events/types.d.ts +214 -0
- package/dist/src/events/types.js +22 -0
- package/dist/src/events/wire.d.ts +114 -0
- package/dist/src/events/wire.js +296 -0
- package/dist/src/fs-monitor-types.d.ts +24 -0
- package/dist/src/fs-monitor-types.js +1 -0
- package/dist/src/fs-monitor.d.ts +80 -0
- package/dist/src/fs-monitor.js +637 -0
- package/dist/src/handlers/auth.d.ts +1 -0
- package/dist/src/handlers/auth.js +170 -0
- package/dist/src/handlers/changes.d.ts +1 -0
- package/dist/src/handlers/changes.js +203 -0
- package/dist/src/handlers/containers.d.ts +12 -0
- package/dist/src/handlers/containers.js +379 -0
- package/dist/src/handlers/databases.d.ts +3 -0
- package/dist/src/handlers/databases.js +327 -0
- package/dist/src/handlers/environments.d.ts +3 -0
- package/dist/src/handlers/environments.js +286 -0
- package/dist/src/handlers/github.d.ts +1 -0
- package/dist/src/handlers/github.js +153 -0
- package/dist/src/handlers/projects.d.ts +1 -0
- package/dist/src/handlers/projects.js +895 -0
- package/dist/src/handlers/ssh.d.ts +1 -0
- package/dist/src/handlers/ssh.js +162 -0
- package/dist/src/handlers/users.d.ts +1 -0
- package/dist/src/handlers/users.js +195 -0
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.js +228 -0
- package/dist/src/mcp/config.d.ts +32 -0
- package/dist/src/mcp/config.js +227 -0
- package/dist/src/mcp/server.d.ts +1 -0
- package/dist/src/mcp/server.js +574 -0
- package/dist/src/serial/cuse-device.d.ts +19 -0
- package/dist/src/serial/cuse-device.js +260 -0
- package/dist/src/serial/manager.d.ts +63 -0
- package/dist/src/serial/manager.js +206 -0
- package/dist/src/serial/pty-pair.d.ts +16 -0
- package/dist/src/serial/pty-pair.js +68 -0
- package/dist/src/services/fs-browser.d.ts +14 -0
- package/dist/src/services/fs-browser.js +98 -0
- package/dist/src/services/git-ops.d.ts +78 -0
- package/dist/src/services/git-ops.js +288 -0
- package/dist/src/services/github-ops.d.ts +104 -0
- package/dist/src/services/github-ops.js +192 -0
- package/dist/src/services/obfuscation.d.ts +2 -0
- package/dist/src/services/obfuscation.js +16 -0
- package/dist/src/services/preview/headless-backend.d.ts +62 -0
- package/dist/src/services/preview/headless-backend.js +698 -0
- package/dist/src/services/preview/injected-scripts.d.ts +9 -0
- package/dist/src/services/preview/injected-scripts.js +232 -0
- package/dist/src/services/preview/preview-backend.d.ts +92 -0
- package/dist/src/services/preview/preview-backend.js +15 -0
- package/dist/src/services/preview/universal-setter.d.ts +7 -0
- package/dist/src/services/preview/universal-setter.js +46 -0
- package/dist/src/services/preview-manager.d.ts +50 -0
- package/dist/src/services/preview-manager.js +216 -0
- package/dist/src/services/project-watcher.d.ts +6 -0
- package/dist/src/services/project-watcher.js +307 -0
- package/dist/src/services/remote-fs-browser.d.ts +11 -0
- package/dist/src/services/remote-fs-browser.js +50 -0
- package/dist/src/services/remote-git-ops.d.ts +71 -0
- package/dist/src/services/remote-git-ops.js +215 -0
- package/dist/src/services/session-search.d.ts +56 -0
- package/dist/src/services/session-search.js +303 -0
- package/dist/src/services/ssh-manager.d.ts +44 -0
- package/dist/src/services/ssh-manager.js +359 -0
- package/dist/src/session-writer.d.ts +9 -0
- package/dist/src/session-writer.js +66 -0
- package/dist/src/spawner.d.ts +56 -0
- package/dist/src/spawner.js +135 -0
- package/dist/src/state/db.d.ts +214 -0
- package/dist/src/state/db.js +897 -0
- package/dist/src/state/store.d.ts +37 -0
- package/dist/src/state/store.js +108 -0
- package/dist/src/state/types.d.ts +13 -0
- package/dist/src/state/types.js +1 -0
- package/dist/src/web/devtools-proxy.d.ts +7 -0
- package/dist/src/web/devtools-proxy.js +176 -0
- package/dist/src/web/port-proxy.d.ts +15 -0
- package/dist/src/web/port-proxy.js +124 -0
- package/dist/src/web/preview-ws.d.ts +5 -0
- package/dist/src/web/preview-ws.js +207 -0
- package/dist/src/web/server.d.ts +6 -0
- package/dist/src/web/server.js +1694 -0
- package/dist/src/ws/agent-ws.d.ts +5 -0
- package/dist/src/ws/agent-ws.js +93 -0
- package/frontend/dist/assets/_basePickBy-B-LibQ4-.js +1 -0
- package/frontend/dist/assets/_baseUniq-CprifHap.js +1 -0
- package/frontend/dist/assets/_createAssigner-ByDUqGii.js +1 -0
- package/frontend/dist/assets/abap-DuT-3z4x.js +1 -0
- package/frontend/dist/assets/addon-fit-CxQet2ja.js +1 -0
- package/frontend/dist/assets/addon-web-links-D_jRkPIl.js +1 -0
- package/frontend/dist/assets/apex-B-em86xX.js +1 -0
- package/frontend/dist/assets/api-SUPuHhSY.js +2 -0
- package/frontend/dist/assets/arc-Z0_eVteO.js +1 -0
- package/frontend/dist/assets/architecture-PBZL5I3N-hvVXGhqd.js +1 -0
- package/frontend/dist/assets/architectureDiagram-2XIMDMQ5-DiHPxX4j.js +36 -0
- package/frontend/dist/assets/array-CwG8vNfn.js +1 -0
- package/frontend/dist/assets/auth-store-R7eW5SVu.js +1 -0
- package/frontend/dist/assets/azcli-Bg9wQloi.js +1 -0
- package/frontend/dist/assets/bat-BM46z99L.js +1 -0
- package/frontend/dist/assets/bicep-DcBsJUfh.js +2 -0
- package/frontend/dist/assets/blockDiagram-WCTKOSBZ-C40u_hLo.js +132 -0
- package/frontend/dist/assets/c4Diagram-IC4MRINW-Ct7LjWFQ.js +10 -0
- package/frontend/dist/assets/cameligo-zw7JTtim.js +1 -0
- package/frontend/dist/assets/channel-ClCsE6HN.js +1 -0
- package/frontend/dist/assets/chunk-4BX2VUAB-zZ6P90VO.js +1 -0
- package/frontend/dist/assets/chunk-55IACEB6-DXllTDQl.js +1 -0
- package/frontend/dist/assets/chunk-7E7YKBS2-7zRaOLjj.js +1 -0
- package/frontend/dist/assets/chunk-7R4GIKGN-Csst1274.js +80 -0
- package/frontend/dist/assets/chunk-C72U2L5F-_JbQPbLN.js +1 -0
- package/frontend/dist/assets/chunk-CFjPhJqf.js +1 -0
- package/frontend/dist/assets/chunk-EGIJ26TM-B--aFyPw.js +1 -0
- package/frontend/dist/assets/chunk-FMBD7UC4-DVR34RNb.js +15 -0
- package/frontend/dist/assets/chunk-GEFDOKGD-CnmN6cC8.js +2 -0
- package/frontend/dist/assets/chunk-JSJVCQXG-CWxHBzeJ.js +1 -0
- package/frontend/dist/assets/chunk-KX2RTZJC-DkRk56s7.js +1 -0
- package/frontend/dist/assets/chunk-KYZI473N-DCCsG2dK.js +53 -0
- package/frontend/dist/assets/chunk-L3YUKLVL-C-DkZTMr.js +1 -0
- package/frontend/dist/assets/chunk-MX3YWQON-OUdzv5sZ.js +1 -0
- package/frontend/dist/assets/chunk-NQ4KR5QH-Bpu9FsM7.js +220 -0
- package/frontend/dist/assets/chunk-O4XLMI2P-BMLK6_ib.js +7 -0
- package/frontend/dist/assets/chunk-OZEHJAEY-CNNiJtG0.js +1 -0
- package/frontend/dist/assets/chunk-PQ6SQG4A-evVHD3KM.js +1 -0
- package/frontend/dist/assets/chunk-PU5JKC2W-DPFTYuvl.js +70 -0
- package/frontend/dist/assets/chunk-QZHKN3VN-JRdddPvu.js +1 -0
- package/frontend/dist/assets/chunk-R5LLSJPH-CHQzVVOV.js +1 -0
- package/frontend/dist/assets/chunk-WL4C6EOR-BNFU6IIi.js +189 -0
- package/frontend/dist/assets/chunk-XIRO2GV7-98T93G85.js +1 -0
- package/frontend/dist/assets/chunk-XZSTWKYB-BcW3cyNp.js +94 -0
- package/frontend/dist/assets/chunk-YBOYWFTD-BgKO1qAJ.js +1 -0
- package/frontend/dist/assets/classDiagram-VBA2DB6C-DikXzgcD.js +1 -0
- package/frontend/dist/assets/classDiagram-v2-RAHNMMFH-D7E3tQUK.js +1 -0
- package/frontend/dist/assets/clojure-FspFoNNQ.js +1 -0
- package/frontend/dist/assets/clone-mOXuZa7C.js +1 -0
- package/frontend/dist/assets/codicon-ngg6Pgfi.ttf +0 -0
- package/frontend/dist/assets/coffee-13n8Bk2W.js +1 -0
- package/frontend/dist/assets/cose-bilkent-S5V4N54A-zUOWQqLe.js +1 -0
- package/frontend/dist/assets/cpp-BVm2xGEs.js +1 -0
- package/frontend/dist/assets/csharp-D2kAWmUm.js +1 -0
- package/frontend/dist/assets/csp-Ezvgpf0e.js +1 -0
- package/frontend/dist/assets/css-CYxRwcFy.js +3 -0
- package/frontend/dist/assets/css.worker-Cd5h-ZOL.js +89 -0
- package/frontend/dist/assets/cssMode-CrXej49V.js +1 -0
- package/frontend/dist/assets/cypher-jg3SGErc.js +1 -0
- package/frontend/dist/assets/cytoscape.esm-kyyvzxNV.js +321 -0
- package/frontend/dist/assets/dagre-DH4bgZO7.js +1 -0
- package/frontend/dist/assets/dagre-KLK3FWXG-DNSqDkwT.js +4 -0
- package/frontend/dist/assets/dart-179jqhK4.js +1 -0
- package/frontend/dist/assets/defaultLocale-Dda4OpKy.js +1 -0
- package/frontend/dist/assets/diagram-E7M64L7V-RqPNT5Vs.js +24 -0
- package/frontend/dist/assets/diagram-IFDJBPK2-B-5NRyaE.js +43 -0
- package/frontend/dist/assets/diagram-P4PSJMXO-BrP69Hk0.js +24 -0
- package/frontend/dist/assets/dist-CU_Nb1G5.js +1 -0
- package/frontend/dist/assets/dockerfile-CIAtSGxS.js +1 -0
- package/frontend/dist/assets/ecl-CGVKfDxD.js +1 -0
- package/frontend/dist/assets/editor-Br_kD0ds.css +1 -0
- package/frontend/dist/assets/editor.api2-YXkDn0Gm.js +872 -0
- package/frontend/dist/assets/editor.main-fBaXZjJ0.js +6 -0
- package/frontend/dist/assets/elixir-BZ-6w0y3.js +1 -0
- package/frontend/dist/assets/erDiagram-INFDFZHY-BYiB9NYg.js +70 -0
- package/frontend/dist/assets/flow9-CVuOjTMv.js +1 -0
- package/frontend/dist/assets/flowDiagram-PKNHOUZH-Cwq47rsR.js +162 -0
- package/frontend/dist/assets/freemarker2-DM-pztJU.js +3 -0
- package/frontend/dist/assets/fsharp-q0pGJYr6.js +1 -0
- package/frontend/dist/assets/ganttDiagram-A5KZAMGK-Dnx3szD9.js +292 -0
- package/frontend/dist/assets/gitGraph-HDMCJU4V-COlTQ7bA.js +1 -0
- package/frontend/dist/assets/gitGraphDiagram-K3NZZRJ6-BaUxboNc.js +65 -0
- package/frontend/dist/assets/go-dzSPfdEO.js +1 -0
- package/frontend/dist/assets/graphlib-kEFlkt3U.js +1 -0
- package/frontend/dist/assets/graphql-CG4OUoEV.js +1 -0
- package/frontend/dist/assets/handlebars-BbK53Vec.js +1 -0
- package/frontend/dist/assets/hcl-Cy14JPk3.js +1 -0
- package/frontend/dist/assets/html-DYtTQNOG.js +1 -0
- package/frontend/dist/assets/html.worker-BjVEKLoU.js +502 -0
- package/frontend/dist/assets/htmlMode-C6GTouth.js +1 -0
- package/frontend/dist/assets/index-DMLxes_u.js +157 -0
- package/frontend/dist/assets/index-DmzeqkB1.css +1 -0
- package/frontend/dist/assets/info-3K5VOQVL-DBtHyA4C.js +1 -0
- package/frontend/dist/assets/infoDiagram-LFFYTUFH-yBXLgMPI.js +2 -0
- package/frontend/dist/assets/ini-Pbg8HGVD.js +1 -0
- package/frontend/dist/assets/init-D6KNwrax.js +1 -0
- package/frontend/dist/assets/ishikawaDiagram-PHBUUO56-Bld4two_.js +70 -0
- package/frontend/dist/assets/java-BmVu6Qrl.js +1 -0
- package/frontend/dist/assets/javascript-PbfQEdcJ.js +1 -0
- package/frontend/dist/assets/journeyDiagram-4ABVD52K-4HyMd4R2.js +139 -0
- package/frontend/dist/assets/json.worker-DqU5Wxnl.js +58 -0
- package/frontend/dist/assets/jsonMode-CASsGppE.js +7 -0
- package/frontend/dist/assets/julia-3cGnieBq.js +1 -0
- package/frontend/dist/assets/kanban-definition-K7BYSVSG-DpgsZmpG.js +89 -0
- package/frontend/dist/assets/katex-CEw3x5bf.js +261 -0
- package/frontend/dist/assets/kotlin-BuWkVcfV.js +1 -0
- package/frontend/dist/assets/less-CJ_VPy2C.js +2 -0
- package/frontend/dist/assets/lexon-BygAuZPu.js +1 -0
- package/frontend/dist/assets/line-CA_wh_TY.js +1 -0
- package/frontend/dist/assets/linear-BAcLW45z.js +1 -0
- package/frontend/dist/assets/liquid-kz84dle6.js +1 -0
- package/frontend/dist/assets/lspLanguageFeatures-C7hAHFn1.js +4 -0
- package/frontend/dist/assets/lua-C8Xs3dCx.js +1 -0
- package/frontend/dist/assets/m3-DTJeKBk4.js +1 -0
- package/frontend/dist/assets/markdown-QCgx8JqZ.js +1 -0
- package/frontend/dist/assets/math-D0YcMJAn.js +1 -0
- package/frontend/dist/assets/mdx-yRw0ap-E.js +1 -0
- package/frontend/dist/assets/mermaid-parser.core-DAeTodBQ.js +4 -0
- package/frontend/dist/assets/mindmap-definition-YRQLILUH-CoNlFyVl.js +68 -0
- package/frontend/dist/assets/mips-DopWaYgE.js +1 -0
- package/frontend/dist/assets/monaco.contribution-DeY0Qei-.js +2 -0
- package/frontend/dist/assets/msdax-BDis4ARV.js +1 -0
- package/frontend/dist/assets/mysql-BV6MLsOI.js +1 -0
- package/frontend/dist/assets/objective-c-B1UuzKs6.js +1 -0
- package/frontend/dist/assets/ordinal-jM7S0YHN.js +1 -0
- package/frontend/dist/assets/packet-RMMSAZCW-FF6-Tmai.js +1 -0
- package/frontend/dist/assets/pascal-BkvESCrc.js +1 -0
- package/frontend/dist/assets/pascaligo-lTy0kZYr.js +1 -0
- package/frontend/dist/assets/path-DNPd7Py7.js +1 -0
- package/frontend/dist/assets/perl-CrtUPXLV.js +1 -0
- package/frontend/dist/assets/pgsql-B9IbNWx2.js +1 -0
- package/frontend/dist/assets/php-CXvQBY2p.js +1 -0
- package/frontend/dist/assets/pie-UPGHQEXC-CFvXY2o-.js +1 -0
- package/frontend/dist/assets/pieDiagram-SKSYHLDU-CM_hbCcn.js +30 -0
- package/frontend/dist/assets/pla-DxBxuqWu.js +1 -0
- package/frontend/dist/assets/postiats-OkEuT5YF.js +1 -0
- package/frontend/dist/assets/powerquery-CMx5Tq4K.js +1 -0
- package/frontend/dist/assets/powershell-CstRxrEc.js +1 -0
- package/frontend/dist/assets/preload-helper-D4M6sveU.js +1 -0
- package/frontend/dist/assets/protobuf-Bx0Z-uRj.js +2 -0
- package/frontend/dist/assets/pug--W8vanWl.js +1 -0
- package/frontend/dist/assets/python-DA0rnlw3.js +1 -0
- package/frontend/dist/assets/qsharp-CRtr0YbN.js +1 -0
- package/frontend/dist/assets/quadrantDiagram-337W2JSQ-B3n3IUhC.js +7 -0
- package/frontend/dist/assets/r-C6E1d6iv.js +1 -0
- package/frontend/dist/assets/radar-KQ55EAFF-MPZu7SdX.js +1 -0
- package/frontend/dist/assets/razor-yd73uata.js +1 -0
- package/frontend/dist/assets/redis-Dx13voP3.js +1 -0
- package/frontend/dist/assets/redshift-D66HwlyV.js +1 -0
- package/frontend/dist/assets/requirementDiagram-Z7DCOOCP-CorP7L7F.js +73 -0
- package/frontend/dist/assets/restructuredtext-DQT2NKJ2.js +1 -0
- package/frontend/dist/assets/rough.esm-DxAX5Vpo.js +1 -0
- package/frontend/dist/assets/ruby-iFXI8hwH.js +1 -0
- package/frontend/dist/assets/rust-CSKiei34.js +1 -0
- package/frontend/dist/assets/sankeyDiagram-WA2Y5GQK-RDx6Bd-B.js +10 -0
- package/frontend/dist/assets/sb-Bo3ttdP2.js +1 -0
- package/frontend/dist/assets/scala-BC1D-Nxp.js +1 -0
- package/frontend/dist/assets/scheme-Z4OAo4Lv.js +1 -0
- package/frontend/dist/assets/scss-BvrdPs6B.js +3 -0
- package/frontend/dist/assets/sequenceDiagram-2WXFIKYE-JMqJSFq6.js +145 -0
- package/frontend/dist/assets/shell-Bh_aCyF-.js +1 -0
- package/frontend/dist/assets/solidity-CWHj6tSe.js +1 -0
- package/frontend/dist/assets/sophia-raoNtKtm.js +1 -0
- package/frontend/dist/assets/sparql-XzmoGnue.js +1 -0
- package/frontend/dist/assets/sql-BD0i9Gvg.js +1 -0
- package/frontend/dist/assets/src-Bn-kKzs7.js +1 -0
- package/frontend/dist/assets/st-DtVKyms6.js +1 -0
- package/frontend/dist/assets/stateDiagram-RAJIS63D-CgFfENdy.js +1 -0
- package/frontend/dist/assets/stateDiagram-v2-FVOUBMTO-C4Hh2P-U.js +1 -0
- package/frontend/dist/assets/swift--UZs77wT.js +1 -0
- package/frontend/dist/assets/systemverilog-CDnBSWUd.js +1 -0
- package/frontend/dist/assets/tcl-DdCEuTHZ.js +1 -0
- package/frontend/dist/assets/timeline-definition-YZTLITO2-BnatPBR5.js +61 -0
- package/frontend/dist/assets/treemap-KZPCXAKY-qb1Pl9la.js +1 -0
- package/frontend/dist/assets/ts.worker-DyPAEIuH.js +67719 -0
- package/frontend/dist/assets/tsMode-iuvyEpyO.js +11 -0
- package/frontend/dist/assets/twig-SSL-Altf.js +1 -0
- package/frontend/dist/assets/typescript-17918Hud.js +1 -0
- package/frontend/dist/assets/typespec-BT7S0ETg.js +1 -0
- package/frontend/dist/assets/vb-CrIgucua.js +1 -0
- package/frontend/dist/assets/vennDiagram-LZ73GAT5-DygS4Zzd.js +34 -0
- package/frontend/dist/assets/wgsl-BeKc3oEp.js +298 -0
- package/frontend/dist/assets/workers-DTfwKVoM.js +1 -0
- package/frontend/dist/assets/xml-CBMr_Wbw.js +1 -0
- package/frontend/dist/assets/xterm-BrP-ENHg.css +1 -0
- package/frontend/dist/assets/xterm-CBX2m0YM.js +36 -0
- package/frontend/dist/assets/xychartDiagram-JWTSCODW-D6wY1Jwd.js +7 -0
- package/frontend/dist/assets/yaml-CTjCH7Bv.js +1 -0
- package/frontend/dist/fonts/inter-300.ttf +0 -0
- package/frontend/dist/fonts/inter-400.ttf +0 -0
- package/frontend/dist/fonts/inter-500.ttf +0 -0
- package/frontend/dist/fonts/inter-600.ttf +0 -0
- package/frontend/dist/fonts/inter-700.ttf +0 -0
- package/frontend/dist/index.html +49 -0
- package/frontend/dist/logo_192x192.png +0 -0
- package/frontend/dist/logo_32x32.png +0 -0
- package/frontend/dist/logo_512x512.png +0 -0
- package/frontend/dist/logo_64x64.png +0 -0
- package/frontend/dist/logobg_192x192.png +0 -0
- package/frontend/dist/logobg_512x512.png +0 -0
- package/frontend/dist/logobg_64x64.png +0 -0
- package/frontend/dist/manifest.json +25 -0
- package/frontend/dist/sw.js +22 -0
- package/package.json +74 -7
- package/preload/Makefile +12 -0
- package/preload/atoo-studio-preload.c +647 -0
- package/preload/atoo-studio-preload.so +0 -0
- package/setup-cuse.sh +260 -0
- package/setup.sh +81 -0
- package/src/serial/native/binding.gyp +10 -0
- package/src/serial/native/pty_pair.c +222 -0
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { execFile } from 'child_process';
|
|
2
|
+
const TIMEOUT = 30000;
|
|
3
|
+
function gh(args, cwd) {
|
|
4
|
+
return new Promise((resolve, reject) => {
|
|
5
|
+
execFile('gh', args, { cwd, timeout: TIMEOUT, maxBuffer: 10 * 1024 * 1024 }, (err, stdout, stderr) => {
|
|
6
|
+
if (err) {
|
|
7
|
+
reject(new Error(stderr?.trim() || err.message));
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
resolve(stdout);
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
function whichGh() {
|
|
16
|
+
return new Promise((resolve) => {
|
|
17
|
+
execFile('which', ['gh'], { timeout: 5000 }, (err) => {
|
|
18
|
+
resolve(!err);
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
// Cache github status per cwd to avoid repeated detection
|
|
23
|
+
const statusCache = new Map();
|
|
24
|
+
const STATUS_CACHE_TTL = 60000; // 1 minute
|
|
25
|
+
export async function getGitHubStatus(cwd) {
|
|
26
|
+
const cached = statusCache.get(cwd);
|
|
27
|
+
if (cached && Date.now() - cached.ts < STATUS_CACHE_TTL) {
|
|
28
|
+
return cached.status;
|
|
29
|
+
}
|
|
30
|
+
const result = { available: false, owner: '', repo: '', canWrite: false };
|
|
31
|
+
// Check if gh is installed
|
|
32
|
+
const hasGh = await whichGh();
|
|
33
|
+
if (!hasGh) {
|
|
34
|
+
result.unavailableReason = 'GitHub CLI (gh) is not installed';
|
|
35
|
+
statusCache.set(cwd, { status: result, ts: Date.now() });
|
|
36
|
+
return result;
|
|
37
|
+
}
|
|
38
|
+
// Check for GitHub remote
|
|
39
|
+
try {
|
|
40
|
+
const remotes = await new Promise((resolve, reject) => {
|
|
41
|
+
execFile('git', ['remote', '-v'], { cwd, timeout: 5000 }, (err, stdout) => {
|
|
42
|
+
if (err)
|
|
43
|
+
reject(err);
|
|
44
|
+
else
|
|
45
|
+
resolve(stdout);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
const ghRemote = remotes.split('\n').find(line => line.includes('github.com') && line.includes('(push)'));
|
|
49
|
+
if (!ghRemote) {
|
|
50
|
+
result.unavailableReason = 'No GitHub remote configured';
|
|
51
|
+
statusCache.set(cwd, { status: result, ts: Date.now() });
|
|
52
|
+
return result;
|
|
53
|
+
}
|
|
54
|
+
// Parse owner/repo from remote URL
|
|
55
|
+
// Handles: git@github.com:owner/repo.git, https://github.com/owner/repo.git, etc.
|
|
56
|
+
const match = ghRemote.match(/github\.com[:/]([^/]+)\/([^/\s]+?)(?:\.git)?(?:\s|$)/);
|
|
57
|
+
if (!match) {
|
|
58
|
+
result.unavailableReason = 'Could not parse GitHub remote URL';
|
|
59
|
+
statusCache.set(cwd, { status: result, ts: Date.now() });
|
|
60
|
+
return result;
|
|
61
|
+
}
|
|
62
|
+
result.owner = match[1];
|
|
63
|
+
result.repo = match[2];
|
|
64
|
+
}
|
|
65
|
+
catch {
|
|
66
|
+
result.unavailableReason = 'No GitHub remote configured';
|
|
67
|
+
statusCache.set(cwd, { status: result, ts: Date.now() });
|
|
68
|
+
return result;
|
|
69
|
+
}
|
|
70
|
+
// Check auth status
|
|
71
|
+
try {
|
|
72
|
+
const authOut = await gh(['auth', 'status'], cwd);
|
|
73
|
+
result.available = true;
|
|
74
|
+
// Check for write scopes
|
|
75
|
+
// gh auth status outputs scopes like: Token scopes: 'delete_repo', 'gist', 'repo', 'workflow'
|
|
76
|
+
const hasRepoScope = /['"]repo['"]/.test(authOut) || /Token scopes:.*\brepo\b/.test(authOut);
|
|
77
|
+
const hasWriteScope = hasRepoScope || /['"]write:/.test(authOut) || /['"]public_repo['"]/.test(authOut);
|
|
78
|
+
result.canWrite = hasWriteScope;
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
// gh auth status exits with error if not authenticated, but may still output info to stderr
|
|
82
|
+
const msg = err.message || '';
|
|
83
|
+
if (msg.includes('Logged in')) {
|
|
84
|
+
result.available = true;
|
|
85
|
+
// Conservative: if we can't parse scopes, assume read-only
|
|
86
|
+
result.canWrite = /\brepo\b/.test(msg);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
result.unavailableReason = 'GitHub CLI not authenticated — run "gh auth login"';
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
statusCache.set(cwd, { status: result, ts: Date.now() });
|
|
93
|
+
return result;
|
|
94
|
+
}
|
|
95
|
+
export function clearStatusCache(cwd) {
|
|
96
|
+
if (cwd) {
|
|
97
|
+
statusCache.delete(cwd);
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
statusCache.clear();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
const ISSUE_FIELDS = 'number,title,state,author,labels,createdAt,updatedAt,comments,url,assignees,milestone';
|
|
104
|
+
const PR_FIELDS = 'number,title,state,author,labels,createdAt,updatedAt,comments,url,headRefName,baseRefName,isDraft,mergeable,reviewDecision,additions,deletions,assignees';
|
|
105
|
+
export async function listIssues(cwd, opts = {}) {
|
|
106
|
+
const { state = 'open', search, limit = 50 } = opts;
|
|
107
|
+
const args = ['issue', 'list', '--json', ISSUE_FIELDS, '--limit', String(limit + 1), '--state', state];
|
|
108
|
+
if (search) {
|
|
109
|
+
args.push('--search', search);
|
|
110
|
+
}
|
|
111
|
+
const out = await gh(args, cwd);
|
|
112
|
+
const items = JSON.parse(out);
|
|
113
|
+
const hasMore = items.length > limit;
|
|
114
|
+
if (hasMore)
|
|
115
|
+
items.length = limit;
|
|
116
|
+
return { items, hasMore };
|
|
117
|
+
}
|
|
118
|
+
export async function listPulls(cwd, opts = {}) {
|
|
119
|
+
const { state = 'open', search, limit = 50 } = opts;
|
|
120
|
+
const args = ['pr', 'list', '--json', PR_FIELDS, '--limit', String(limit + 1), '--state', state];
|
|
121
|
+
if (search) {
|
|
122
|
+
args.push('--search', search);
|
|
123
|
+
}
|
|
124
|
+
const out = await gh(args, cwd);
|
|
125
|
+
const items = JSON.parse(out);
|
|
126
|
+
const hasMore = items.length > limit;
|
|
127
|
+
if (hasMore)
|
|
128
|
+
items.length = limit;
|
|
129
|
+
return { items, hasMore };
|
|
130
|
+
}
|
|
131
|
+
const ISSUE_DETAIL_FIELDS = ISSUE_FIELDS + ',body';
|
|
132
|
+
const PR_DETAIL_FIELDS = PR_FIELDS + ',body';
|
|
133
|
+
export async function getIssueDetail(cwd, number) {
|
|
134
|
+
const out = await gh(['issue', 'view', String(number), '--json', ISSUE_DETAIL_FIELDS], cwd);
|
|
135
|
+
const issue = JSON.parse(out);
|
|
136
|
+
// Fetch comments separately
|
|
137
|
+
const commentsOut = await gh(['issue', 'view', String(number), '--json', 'comments'], cwd);
|
|
138
|
+
const { comments: commentsList } = JSON.parse(commentsOut);
|
|
139
|
+
return {
|
|
140
|
+
...issue,
|
|
141
|
+
comments_list: (commentsList || []).map((c) => ({
|
|
142
|
+
author: c.author,
|
|
143
|
+
body: c.body,
|
|
144
|
+
createdAt: c.createdAt,
|
|
145
|
+
updatedAt: c.updatedAt,
|
|
146
|
+
})),
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
export async function getPullDetail(cwd, number) {
|
|
150
|
+
const out = await gh(['pr', 'view', String(number), '--json', PR_DETAIL_FIELDS], cwd);
|
|
151
|
+
const pull = JSON.parse(out);
|
|
152
|
+
// Fetch comments separately
|
|
153
|
+
const commentsOut = await gh(['pr', 'view', String(number), '--json', 'comments'], cwd);
|
|
154
|
+
const { comments: commentsList } = JSON.parse(commentsOut);
|
|
155
|
+
return {
|
|
156
|
+
...pull,
|
|
157
|
+
comments_list: (commentsList || []).map((c) => ({
|
|
158
|
+
author: c.author,
|
|
159
|
+
body: c.body,
|
|
160
|
+
createdAt: c.createdAt,
|
|
161
|
+
updatedAt: c.updatedAt,
|
|
162
|
+
})),
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
export async function updateIssueState(cwd, number, action) {
|
|
166
|
+
if (action === 'close') {
|
|
167
|
+
await gh(['issue', 'close', String(number)], cwd);
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
await gh(['issue', 'reopen', String(number)], cwd);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
export async function updatePullState(cwd, number, action) {
|
|
174
|
+
if (action === 'close') {
|
|
175
|
+
await gh(['pr', 'close', String(number)], cwd);
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
await gh(['pr', 'reopen', String(number)], cwd);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
export async function createPullRequest(cwd, opts) {
|
|
182
|
+
const args = ['pr', 'create', '--title', opts.title];
|
|
183
|
+
if (opts.body)
|
|
184
|
+
args.push('--body', opts.body);
|
|
185
|
+
if (opts.base)
|
|
186
|
+
args.push('--base', opts.base);
|
|
187
|
+
const out = await gh(args, cwd);
|
|
188
|
+
// gh pr create outputs the PR URL on the last line
|
|
189
|
+
const url = out.trim().split('\n').pop() || '';
|
|
190
|
+
const numMatch = url.match(/\/pull\/(\d+)/);
|
|
191
|
+
return { number: numMatch ? parseInt(numMatch[1]) : 0, url };
|
|
192
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// Simple XOR + base64 obfuscation — NOT encryption, just prevents casual reading
|
|
2
|
+
const XOR_KEY = 'atoo-studio-ssh-obfuscation-key-2024';
|
|
3
|
+
export function obfuscate(plaintext) {
|
|
4
|
+
const buf = Buffer.from(plaintext, 'utf-8');
|
|
5
|
+
for (let i = 0; i < buf.length; i++) {
|
|
6
|
+
buf[i] ^= XOR_KEY.charCodeAt(i % XOR_KEY.length);
|
|
7
|
+
}
|
|
8
|
+
return buf.toString('base64');
|
|
9
|
+
}
|
|
10
|
+
export function deobfuscate(encoded) {
|
|
11
|
+
const buf = Buffer.from(encoded, 'base64');
|
|
12
|
+
for (let i = 0; i < buf.length; i++) {
|
|
13
|
+
buf[i] ^= XOR_KEY.charCodeAt(i % XOR_KEY.length);
|
|
14
|
+
}
|
|
15
|
+
return buf.toString('utf-8');
|
|
16
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Browser, Page, CDPSession } from 'puppeteer';
|
|
2
|
+
import { PreviewBackend, PreviewInstanceBase, CreatePreviewOpts } from './preview-backend.js';
|
|
3
|
+
export interface HeadlessInstance extends PreviewInstanceBase {
|
|
4
|
+
browser: Browser;
|
|
5
|
+
page: Page;
|
|
6
|
+
cdpSession: CDPSession;
|
|
7
|
+
browserCdpSession: CDPSession;
|
|
8
|
+
cdpPort: number;
|
|
9
|
+
screencastActive: boolean;
|
|
10
|
+
pendingAuthRequests: Map<string, {
|
|
11
|
+
requestId: string;
|
|
12
|
+
timeout: ReturnType<typeof setTimeout>;
|
|
13
|
+
}>;
|
|
14
|
+
}
|
|
15
|
+
export declare class HeadlessBackend implements PreviewBackend {
|
|
16
|
+
readonly mode: "headless";
|
|
17
|
+
private usedPorts;
|
|
18
|
+
cleanupOrphans(): void;
|
|
19
|
+
private allocateCdpPort;
|
|
20
|
+
private isPortFree;
|
|
21
|
+
private releaseCdpPort;
|
|
22
|
+
private startScreencast;
|
|
23
|
+
private stopScreencast;
|
|
24
|
+
private setupInterception;
|
|
25
|
+
private setupInjectedScripts;
|
|
26
|
+
private setupAuthInterception;
|
|
27
|
+
create(key: string, opts: CreatePreviewOpts): Promise<HeadlessInstance>;
|
|
28
|
+
destroy(instance: PreviewInstanceBase): Promise<void>;
|
|
29
|
+
private viewportTimers;
|
|
30
|
+
setViewport(instance: PreviewInstanceBase, viewport: {
|
|
31
|
+
width: number;
|
|
32
|
+
height: number;
|
|
33
|
+
dpr?: number;
|
|
34
|
+
isMobile?: boolean;
|
|
35
|
+
hasTouch?: boolean;
|
|
36
|
+
}): Promise<void>;
|
|
37
|
+
setQuality(instance: PreviewInstanceBase, quality: number): Promise<void>;
|
|
38
|
+
navigate(instance: PreviewInstanceBase, url: string): Promise<void>;
|
|
39
|
+
reload(instance: PreviewInstanceBase): Promise<void>;
|
|
40
|
+
dispatchMouseEvent(instance: PreviewInstanceBase, params: any): Promise<void>;
|
|
41
|
+
dispatchKeyEvent(instance: PreviewInstanceBase, params: any): Promise<void>;
|
|
42
|
+
insertText(instance: PreviewInstanceBase, text: string): Promise<void>;
|
|
43
|
+
dispatchScrollEvent(instance: PreviewInstanceBase, params: {
|
|
44
|
+
x: number;
|
|
45
|
+
y: number;
|
|
46
|
+
deltaX: number;
|
|
47
|
+
deltaY: number;
|
|
48
|
+
}): Promise<void>;
|
|
49
|
+
screenshot(instance: PreviewInstanceBase, fullPage?: boolean): Promise<string>;
|
|
50
|
+
handleDialogResponse(instance: PreviewInstanceBase, dialogId: string, accept: boolean, promptText?: string): void;
|
|
51
|
+
handleFileChooserResponse(instance: PreviewInstanceBase, backendNodeId: number, files: string[]): Promise<void>;
|
|
52
|
+
getDownloadPath(instance: PreviewInstanceBase, guid: string): string | null;
|
|
53
|
+
startRecording(instance: PreviewInstanceBase): void;
|
|
54
|
+
stopRecording(instance: PreviewInstanceBase): Promise<string>;
|
|
55
|
+
restartStream(instance: PreviewInstanceBase): Promise<void>;
|
|
56
|
+
handleSelectResponse(instance: PreviewInstanceBase, selectorPath: string, value: string): Promise<void>;
|
|
57
|
+
handlePickerResponse(instance: PreviewInstanceBase, selectorPath: string, value: string, inputType: string): Promise<void>;
|
|
58
|
+
handleAuthResponse(instance: PreviewInstanceBase, requestId: string, username: string, password: string): void;
|
|
59
|
+
handleAuthCancel(instance: PreviewInstanceBase, requestId: string): void;
|
|
60
|
+
handleContextMenuAction(instance: PreviewInstanceBase, action: string, params: any): Promise<void>;
|
|
61
|
+
shutdown(): Promise<void>;
|
|
62
|
+
}
|