sootsim 0.1.89 → 0.1.91
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/dist-cli/bin.js +3 -3
- package/dist-cli/chunks/{agent-OMQOBVTN.js → agent-RDJ5OOIL.js} +2 -2
- package/dist-cli/chunks/{agent-wrapper-2KXBGMGM.js → agent-wrapper-K2XIYABM.js} +2 -2
- package/dist-cli/chunks/{assert-KVPE3WA7.js → assert-MOH6CTD2.js} +2 -2
- package/dist-cli/chunks/auto-bootstrap-24A5RRBQ.js +2 -0
- package/dist-cli/chunks/beta-IGE75E4B.js +2 -0
- package/dist-cli/chunks/{chunk-4FOEYBND.js → chunk-2Q32WWKY.js} +1 -1
- package/dist-cli/chunks/{chunk-K5LC4CBM.js → chunk-3EQCMOTV.js} +3 -3
- package/dist-cli/chunks/{chunk-EYHJPH7C.js → chunk-3FMTRV2A.js} +2 -2
- package/dist-cli/chunks/{chunk-CPVZ46IS.js → chunk-3IUIN356.js} +1 -1
- package/dist-cli/chunks/{chunk-RX3LQRCU.js → chunk-4DTA5UKZ.js} +2 -2
- package/dist-cli/chunks/chunk-4WUXZXWE.js +1 -0
- package/dist-cli/chunks/chunk-54EVAG4O.js +119 -0
- package/dist-cli/chunks/{chunk-KPSFSCKG.js → chunk-5DYLJJRL.js} +2 -2
- package/dist-cli/chunks/{chunk-LJXW33TJ.js → chunk-63E34ET7.js} +2 -2
- package/dist-cli/chunks/{chunk-WJVBMLUZ.js → chunk-6R3S7M66.js} +2 -2
- package/dist-cli/chunks/{chunk-NCUPGVD4.js → chunk-7HFHTCKD.js} +2 -2
- package/dist-cli/chunks/{chunk-3WTHDJJG.js → chunk-7WLL6LH4.js} +2 -2
- package/dist-cli/chunks/{chunk-HG5VVLD6.js → chunk-ACWM3RKN.js} +2 -2
- package/dist-cli/chunks/{chunk-3EOBQIPI.js → chunk-APQYD7HL.js} +2 -2
- package/dist-cli/chunks/chunk-AWEEXX2S.js +12 -0
- package/dist-cli/chunks/{chunk-HBQGKYCA.js → chunk-B6NQHHMB.js} +2 -2
- package/dist-cli/chunks/chunk-D3J6G7JL.js +2 -0
- package/dist-cli/chunks/{chunk-DUGUYL7H.js → chunk-DFDRE6OB.js} +1 -1
- package/dist-cli/chunks/{chunk-PIRJFIZF.js → chunk-DUPGSOQC.js} +1 -1
- package/dist-cli/chunks/{chunk-WSPJ3KNV.js → chunk-HUUC3TYH.js} +1 -1
- package/dist-cli/chunks/{chunk-W5CC6JIX.js → chunk-J6GWUBW3.js} +2 -2
- package/dist-cli/chunks/{chunk-HM762PMQ.js → chunk-KRZU6LRW.js} +2 -2
- package/dist-cli/chunks/{chunk-OHEIXPMP.js → chunk-LQQUA6BP.js} +2 -2
- package/dist-cli/chunks/{chunk-OWU7TBIS.js → chunk-MERAEG54.js} +1 -1
- package/dist-cli/chunks/{chunk-QG3METGX.js → chunk-NAB63JVH.js} +1 -1
- package/dist-cli/chunks/chunk-OT7LR5RE.js +1 -0
- package/dist-cli/chunks/{chunk-7GNTDMT5.js → chunk-QWYIMQHF.js} +1 -1
- package/dist-cli/chunks/{chunk-DRZRPFKM.js → chunk-QX6G6HA2.js} +1 -1
- package/dist-cli/chunks/{chunk-YSORRTVM.js → chunk-RL7P7EQA.js} +2 -2
- package/dist-cli/chunks/{chunk-ZVNQENKL.js → chunk-SISOWHRQ.js} +3 -3
- package/dist-cli/chunks/{chunk-IVRX3TEH.js → chunk-T3CUB2ZH.js} +2 -2
- package/dist-cli/chunks/{chunk-ETWRACG5.js → chunk-T77FN74G.js} +2 -2
- package/dist-cli/chunks/{chunk-ZV62LZGY.js → chunk-TBIILRLW.js} +3 -3
- package/dist-cli/chunks/chunk-TVRQ3SOL.js +79 -0
- package/dist-cli/chunks/{chunk-4FHMNPCF.js → chunk-UBF3TGKU.js} +2 -2
- package/dist-cli/chunks/{chunk-I5WPAK2A.js → chunk-VFFWR44I.js} +1 -1
- package/dist-cli/chunks/{chunk-SHJOEOUO.js → chunk-VQSP53OC.js} +9 -4
- package/dist-cli/chunks/{chunk-Q57ZMHYI.js → chunk-W3AG5PFE.js} +2 -2
- package/dist-cli/chunks/{chunk-SITJ5S5B.js → chunk-W7I7OUOK.js} +1 -1
- package/dist-cli/chunks/chunk-WQQQQZUL.js +2 -0
- package/dist-cli/chunks/chunk-XVHJZCMT.js +1 -0
- package/dist-cli/chunks/{chunk-2V2FWDAF.js → chunk-Y53I2KD4.js} +1 -1
- package/dist-cli/chunks/{chunk-TVMYLEWA.js → chunk-YK4I75GA.js} +1 -1
- package/dist-cli/chunks/cli-version-B7YMJ7C3.js +2 -0
- package/dist-cli/chunks/{compat-PLXA5SK3.js → compat-XMDCTR7Q.js} +3 -3
- package/dist-cli/chunks/{config-TAK6HN7F.js → config-6EJMWP2Q.js} +2 -2
- package/dist-cli/chunks/{control-CL6MOJ6C.js → control-OQTVATE3.js} +2 -2
- package/dist-cli/chunks/cpu-profile-3K4EHQGQ.js +2 -0
- package/dist-cli/chunks/{daemon-M36WKR5U.js → daemon-OIVJUCY4.js} +2 -2
- package/dist-cli/chunks/{debug-DVITFXQJ.js → debug-EUROZ7TJ.js} +3 -3
- package/dist-cli/chunks/{detox-NV2TRX24.js → detox-H2BVWCR3.js} +2 -2
- package/dist-cli/chunks/{device-VW7O4447.js → device-GIPGWDDE.js} +2 -2
- package/dist-cli/chunks/{diagnose-46BV5GDH.js → diagnose-AM5HDCQZ.js} +2 -2
- package/dist-cli/chunks/drivers-FHFWDATI.js +2 -0
- package/dist-cli/chunks/{electron-OEHJRNA7.js → electron-QUB2SALE.js} +3 -3
- package/dist-cli/chunks/flow-M7CBSQZU.js +2 -0
- package/dist-cli/chunks/help-YQ6FPCDR.js +2 -0
- package/dist-cli/chunks/{hints-ERI46BDJ.js → hints-6CRRYE4S.js} +2 -2
- package/dist-cli/chunks/{home-paths-AYPEAQXA.js → home-paths-GRVUKYNB.js} +2 -2
- package/dist-cli/chunks/{inspect-G72QMXPL.js → inspect-EOMNE3FJ.js} +3 -3
- package/dist-cli/chunks/install-LQPKZ4RZ.js +2 -0
- package/dist-cli/chunks/{install-desktop-KAMMVODZ.js → install-desktop-XZWIGLQT.js} +3 -3
- package/dist-cli/chunks/{keys-QY7KAAYQ.js → keys-IY6T6KCR.js} +2 -2
- package/dist-cli/chunks/{launch-ZNXRIQDN.js → launch-BAZXORER.js} +3 -3
- package/dist-cli/chunks/{login-UHQ25HGD.js → login-VOJRQBIA.js} +4 -4
- package/dist-cli/chunks/{logout-TFVBF3HC.js → logout-VO3X64AP.js} +2 -2
- package/dist-cli/chunks/{maestro-UFAPY6T6.js → maestro-FSBGGAAM.js} +2 -2
- package/dist-cli/chunks/{preview-TLVWJA45.js → preview-27HTOBLN.js} +2 -2
- package/dist-cli/chunks/{profile-JSHBEXKJ.js → profile-MQJB6RE7.js} +2 -2
- package/dist-cli/chunks/{react-CFK5WWST.js → react-6M6SL4E4.js} +2 -2
- package/dist-cli/chunks/{record-YWLFSTDG.js → record-6T6IEYQU.js} +2 -2
- package/dist-cli/chunks/runtime-PFOAMDWK.js +2 -0
- package/dist-cli/chunks/{runtime-delivery-BFTTQ7QC.js → runtime-delivery-O27SF4YJ.js} +2 -2
- package/dist-cli/chunks/{screenshot-PGVRESEV.js → screenshot-S4XVNQWB.js} +2 -2
- package/dist-cli/chunks/{screenshot-mode-LDJLLQ3D.js → screenshot-mode-NRJVIBSH.js} +2 -2
- package/dist-cli/chunks/{screenshots-7PL4PYGS.js → screenshots-6DEGG6X3.js} +2 -2
- package/dist-cli/chunks/{server-6IGCTIJN.js → server-VZC2QSL7.js} +2 -2
- package/dist-cli/chunks/setup-repo-WGDJ6VJ2.js +2 -0
- package/dist-cli/chunks/{skills-VHQGU7GE.js → skills-FWHY4IXO.js} +2 -2
- package/dist-cli/chunks/{start-CAYFJPJF.js → start-AEQJJVJX.js} +4 -4
- package/dist-cli/chunks/store-G3Z5MP57.js +2 -0
- package/dist-cli/chunks/telemetry-74YV3IF3.js +2 -0
- package/dist-cli/chunks/{test-GKUWJJKZ.js → test-OKNHRAIV.js} +3 -3
- package/dist-cli/chunks/{three-mode-2VQX6IIB.js → three-mode-GDBEW2PB.js} +2 -2
- package/dist-cli/chunks/{timeline-IBWWDCOC.js → timeline-YIZEXSB3.js} +2 -2
- package/dist-cli/chunks/{upgrade-SFR57VWD.js → upgrade-XJTQY36G.js} +2 -2
- package/dist-cli/chunks/upload-6VFUC5HN.js +2 -0
- package/dist-cli/chunks/{web-Y3TQSZKE.js → web-MOMUT4FJ.js} +2 -2
- package/dist-cli/chunks/{what-happened-OOWZOYJ5.js → what-happened-W2YJQSUS.js} +2 -2
- package/dist-cli/chunks/{whoami-YCS5L53Z.js → whoami-GRP3K4G3.js} +2 -2
- package/dist-lib/agent-daemon-client.cjs +1 -1
- package/dist-lib/agent-events.cjs +1 -1
- package/dist-lib/agent-sessions.cjs +1 -1
- package/dist-lib/attached-projects.cjs +1 -1
- package/dist-lib/auth/shared-session.cjs +1 -1
- package/dist-lib/backend-origin.cjs +1 -1
- package/dist-lib/beta.cjs +1 -1
- package/dist-lib/beta.mjs +1 -1
- package/dist-lib/bridge-constants.cjs +1 -1
- package/dist-lib/cli-constants.cjs +1 -1
- package/dist-lib/config.cjs +1 -1
- package/dist-lib/detox/index.cjs +1 -1
- package/dist-lib/dev-bundle-resolution.cjs +1 -1
- package/dist-lib/home-paths.cjs +1 -1
- package/dist-lib/host/bridge-host.cjs +1 -1
- package/dist-lib/host/fetch-proxy-handler.cjs +1 -1
- package/dist-lib/host/fetch-proxy-overrides.cjs +1 -1
- package/dist-lib/host/fetch-proxy-overrides.mjs +1 -1
- package/dist-lib/host/websocket-proxy.cjs +1 -1
- package/dist-lib/index.cjs +1 -1
- package/dist-lib/metro.cjs +1 -1
- package/dist-lib/profiles.cjs +1 -1
- package/dist-lib/render-mode.cjs +1 -1
- package/dist-lib/scripts/demo-app-registry.cjs +1 -1
- package/dist-lib/scripts/dev-server-scanner.cjs +1 -1
- package/dist-lib/skills.cjs +1 -1
- package/dist-lib/vite.cjs +1 -1
- package/package.json +1 -1
- package/dist-cli/chunks/auto-bootstrap-NSSS6RYN.js +0 -2
- package/dist-cli/chunks/beta-6RNNGY7M.js +0 -2
- package/dist-cli/chunks/chunk-5ATB3BNQ.js +0 -12
- package/dist-cli/chunks/chunk-6GC4TL3O.js +0 -79
- package/dist-cli/chunks/chunk-6GITV57W.js +0 -1
- package/dist-cli/chunks/chunk-EXHZED5X.js +0 -2
- package/dist-cli/chunks/chunk-L54TZZAI.js +0 -119
- package/dist-cli/chunks/chunk-MHT2T5KD.js +0 -1
- package/dist-cli/chunks/chunk-QSLG7VVY.js +0 -1
- package/dist-cli/chunks/chunk-TRTHHT4P.js +0 -2
- package/dist-cli/chunks/cli-version-YILQNPVD.js +0 -2
- package/dist-cli/chunks/cpu-profile-RZR7QUYN.js +0 -2
- package/dist-cli/chunks/drivers-K7GBED3K.js +0 -2
- package/dist-cli/chunks/flow-4OKAL4KU.js +0 -2
- package/dist-cli/chunks/help-P2ZPKY2O.js +0 -2
- package/dist-cli/chunks/install-WAKFTJUK.js +0 -2
- package/dist-cli/chunks/runtime-73OCON3C.js +0 -2
- package/dist-cli/chunks/setup-repo-PUBU6CFG.js +0 -2
- package/dist-cli/chunks/store-R53SRYMZ.js +0 -2
- package/dist-cli/chunks/telemetry-JTRSVBLT.js +0 -2
- package/dist-cli/chunks/upload-UWFOTY2Q.js +0 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
2
|
-
import{A as y,L as x,y as F,z as T}from"./chunk-
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
+
import{A as y,L as x,y as F,z as T}from"./chunk-HUUC3TYH.js";import{c as S,e as N}from"./chunk-T3CUB2ZH.js";import{b as k}from"./chunk-QWYIMQHF.js";import"./chunk-WQQQQZUL.js";import"./chunk-2Q32WWKY.js";import"./chunk-YK4I75GA.js";function _(n){let e=[];for(let t=0;t<n.length;t++)if(n[t]==="--since"&&t+1<n.length){e.push(t,t+1);let s=n[t+1].trim(),l=/^(\d+(?:\.\d+)?)(ms|s|m)?$/.exec(s);if(l){let a=Number(l[1]),m=l[2]??"ms",$=m==="s"?a*1e3:m==="m"?a*6e4:a;return{since:Date.now()-$,consumed:e}}let o=Number(s);if(Number.isFinite(o)&&o>1e12)return{since:o,consumed:e}}return{consumed:e}}function K(n){let e=[];for(let t=0;t<n.length;t++)if(n[t]==="--kinds"&&t+1<n.length)return e.push(t,t+1),{kinds:n[t+1].split(",").map(s=>s.trim()).filter(Boolean),consumed:e};return{consumed:e}}function O(n){let e=[];for(let t=0;t<n.length;t++)if(n[t]==="--limit"&&t+1<n.length){e.push(t,t+1);let s=Number(n[t+1]);if(Number.isFinite(s)&&s>0)return{limit:s,consumed:e}}return{consumed:e}}function j(n,e){if(e===null)return new Date(n).toLocaleTimeString();let t=(n-e)/1e3;return`${t>=0?"+":""}${t.toFixed(2)}s`}function B(n,e){switch(n){case"app-launch":return e.phase==="launch"?`launch ${e.appName??e.toAppId??""}`:`dismiss ${e.appName??e.fromAppId??""} \u2192 ${e.toAppId??""}`;case"toast":return`"${e.text??""}"${e.durationMs?` (${e.durationMs}ms)`:""}`;case"keyboard":return`${e.phase??"?"}${e.heightPx?` h=${e.heightPx}`:""}${e.mode?` ${e.mode}`:""}`;case"screen":return`${e.phase??"?"} ${e.name??e.activeName??""}`;case"route":return`${e.phase??"?"} ${e.path??e.pathname??""}`;case"alert":case"actionsheet":case"picker":return`${e.phase??"?"} ${e.title??e.message??""}`;case"notification":return`${e.title??""}${e.body?` \u2014 ${e.body}`:""}`;case"fetch":return`${e.method??"GET"} ${e.url??""}${e.status?` -> ${e.status}`:""}`;case"console":return`${e.level??"log"}: ${(e.message??"").toString().slice(0,120)}`;case"shell":return`${e.event??e.type??e.phase??""}`;case"scroll":return`${e.phase??"?"} ${e.target??""}`;case"gesture":return`${e.phase??"?"} ${e.type??""}`;case"text-input":return`${e.phase??"?"}${e.value!==void 0?` "${String(e.value).slice(0,40)}"`:""}`;case"layout":return`${e.kind??"?"} ${e.testID??e.type??""}${e.skipped?` skipped:${e.reason??"unknown"}`:""}`;case"react-commit":{let t=e.slowest;return`${e.fiberCount??"?"} fibers ${e.durationMs??"?"}ms${t?.displayName?` \xB7 ${t.displayName} ${t.durationMs??"?"}ms`:""}`}case"reanimated":case"animation":return`${e.kind??""} ${e.target??""}${e.durationMs?` ${e.durationMs}ms`:""}`}}function A(n,e){let t=j(n.t,e).padStart(8),s=n.context.padEnd(6),l=`[${n.kind}]`.padEnd(15),o="",a=n.data;return a&&typeof a=="object"&&(o=B(n.kind,a)),` ${t} ${s} ${l} ${o}`}function M(n){let e=[],t={label:"initial state",events:[],startedAt:n[0]?.t??null};e.push(t);for(let s of n)if(t.events.push(s),s.kind==="screen"||s.kind==="route"){let l=s.data,o=l?.phase;if(!o||o==="enter"||o==="appear"||o==="active"){let a=l?.name||l?.activeName||l?.path||l?.pathname||s.kind;e.length===1&&t.events.length===1?t.label=`${s.kind}: ${a}`:(t={label:`${s.kind}: ${a}`,events:[],startedAt:s.t},e.push(t))}}return e}async function J(n,e){let t=S(n,{port:e.port,stripBooleanFlags:["--summary","--all","--json","--no-advance","--help","-h","--flow","--noisy"],stripValueFlags:["--since","--kinds","--limit"]});(n.includes("--help")||n.includes("-h"))&&(console.log(`
|
|
3
3
|
sootsim what-happened \u2014 show recent events from the semantic timeline
|
|
4
4
|
|
|
5
5
|
usage:
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
2
|
-
import{d as i}from"./chunk-
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
+
import{d as i}from"./chunk-LQQUA6BP.js";import{d as n}from"./chunk-J6GWUBW3.js";import"./chunk-2Q32WWKY.js";import"./chunk-YK4I75GA.js";async function u(){let o=i();if(o||(console.log(" not signed in"),console.log(" set SOOTSIM_API_KEY=sk_sootsim_\u2026 or run `sootsim login`"),process.exit(1)),o.kind==="api-key"){let r=`${o.secret.slice(0,14)}\u2026`,t=o.source==="env"?"SOOTSIM_API_KEY env var":"saved key (~/.config/sootsim/credentials.json)";console.log(` api key ${r}`),console.log(` source: ${t}`);return}if(o.kind==="github"){console.log(` github token (${o.source})`),console.log(` repo: ${o.repoId}`);return}let e=await n(),s=e?.user;console.log(` ${s?.email||s?.name||s?.id||"signed in"}`),console.log(` origin: ${e?.origin??o.origin}`),e?.updatedAt&&console.log(` updated: ${e.updatedAt}`)}export{u as runWhoami};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
package/dist-lib/beta.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
package/dist-lib/beta.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
package/dist-lib/config.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
package/dist-lib/detox/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
package/dist-lib/home-paths.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
|
|
3
3
|
// src/host/fetch-proxy-overrides.ts
|
|
4
4
|
var FETCH_PROXY_BROWSER_USER_AGENT = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/146.0.0.0 Safari/537.36";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
package/dist-lib/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
package/dist-lib/metro.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
package/dist-lib/profiles.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
package/dist-lib/render-mode.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __defProp = Object.defineProperty;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
package/dist-lib/skills.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
package/dist-lib/vite.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.91 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
2
|
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
3
|
"use strict";
|
|
4
4
|
var __create = Object.create;
|
package/package.json
CHANGED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
/*! sootsim v0.1.89 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
-
import{a,b,c,d}from"./chunk-ZVNQENKL.js";import"./chunk-IVRX3TEH.js";import"./chunk-7GNTDMT5.js";import"./chunk-EXHZED5X.js";import"./chunk-4FOEYBND.js";import"./chunk-TVMYLEWA.js";export{c as ensureDaemonRunning,a as ensureRuntimeInstalled,d as ensureSootsimReady,b as resolveBootstrapPort};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/*! sootsim v0.1.89 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
-
import{a as _,b as j,c as le,e as ce}from"./chunk-HG5VVLD6.js";import{m as O}from"./chunk-WJVBMLUZ.js";import{j as se,k as ie,m as ae}from"./chunk-WSPJ3KNV.js";import{b as re,c as I,d as S,e as x}from"./chunk-IVRX3TEH.js";import{c as k,d as w,e as P}from"./chunk-7GNTDMT5.js";import{g as q}from"./chunk-SHJOEOUO.js";import{a as C,b as W}from"./chunk-QG3METGX.js";import{c as de}from"./chunk-3EOBQIPI.js";import{d as z}from"./chunk-PIRJFIZF.js";import{a as ne}from"./chunk-TRTHHT4P.js";import{E as te,F as oe}from"./chunk-4FOEYBND.js";import ve from"node:fs";import Re from"node:os";import V from"node:path";function Pe(t){return t.replace(/^\[|\]$/g,"").toLowerCase()}function G(t){let o=Pe(t);return o==="localhost"||o.endsWith(".localhost")||o==="0.0.0.0"||o==="::1"||/^127(?:\.\d{1,3}){3}$/.test(o)}function me(t){return new Error(`could not resolve a native bundle for ${t}. pass an explicit bundle URL or open Connect and choose the app there.`)}function Ce(t,o){return t?.includes("/one/metro-entry.bundle")?"one":typeof o=="string"&&o?"expo":"unknown"}function fe(t,o,e){return`${t}//${o}:${e}`}function Be(t){if(typeof window>"u")return!1;try{let o=new URL(t);return G(o.hostname)&&G(window.location.hostname)&&o.origin!==window.location.origin}catch{return!1}}async function ue(t,o){let e={...o,cache:o?.cache??"no-store"};return Be(t)?fetch(`/__fetch-proxy?url=${encodeURIComponent(t)}`,e):fetch(t,e)}function Te(t){return t==="https:"?443:80}function Me(t){let o=t.pathname||"/";return(o==="/"||o==="")&&!t.search&&!t.hash}async function ge(t,o){let e=t.replace(/\/+$/,"");try{let n=await ue(`${e}/`,{headers:{"expo-platform":"ios"}});if(n.ok){let r=await n.json(),s=r?.extra?.expoClient||r?.extra||{},a=typeof r?.launchAsset?.url=="string"?r.launchAsset.url:void 0;if(a||s.name)return{bundleUrl:le(a||`${e}${j}`),port:o,framework:Ce(a,s.sdkVersion),projectName:s.name}}}catch{}try{let n=await ue(`${e}/status`);if(n.ok&&(await n.text()).includes("packager-status:running"))return{bundleUrl:`${e}${j}`,port:o,framework:"metro"}}catch{}return null}async function pe(t){return ge(fe("http:","localhost",t),t)}async function he(t){let o=t.trim();if(/^\d+$/.test(o)){let i=parseInt(o,10),l=await pe(i);if(l)return l;let c=3;for(let d=1;d<=c;d++){let p=await pe(i+d);if(p)return p}throw me(`localhost:${i} (also scanned +1..+${c})`)}let e=o.startsWith("http")?o:`http://${o}`,n;try{n=new URL(e)}catch{throw new Error(`could not parse "${t}". pass a dev-server port, a dev-server base URL, or a full bundle URL.`)}let r=n.protocol||"http:",s=n.port?parseInt(n.port,10):Te(r),a=fe(r,n.hostname,s);if(Me(n)){let i=await ge(a,s);if(i)return i;throw me(a)}return{bundleUrl:n.toString(),port:s,framework:"unknown"}}function rt(){console.error(" no sootsim desktop companion found."),console.error(""),console.error(" install the desktop app:"),console.error(" sootsim install-desktop"),console.error(""),console.error(" or wire sootsim into your own project so your dev server hosts the bridge:"),console.error(" sootsim setup-repo"),console.error("")}function we(t){let o=C();if(console.log(` note: no sootsim bridge detected on port ${t}`),o){console.log(" launch the installed companion with:"),console.log(" sootsim electron");return}console.log(""),console.log(" to get a bridge running, either:"),console.log(" sootsim install-desktop # download the electron app"),console.log(" sootsim setup-repo # wire sootsim into your own project")}function Ue(t){console.error(""),console.error(` no sim is connected to the sootsim bridge on port ${t}.`),console.error(""),console.error(" start your app dev server, then open it in sootsim:"),console.error(" npx expo start --localhost --port 8081"),console.error(" sootsim open 8081"),console.error(""),console.error(" then inspect the live app:"),console.error(" sootsim describe")}async function st(t,o,e){let n=[];try{n=await t.listSims()}catch{}if(console.error(""),n.length===0){Ue(o);return}console.error(` no sim with id "${e}" is connected to the bridge on port ${o}.`),console.error(""),console.error(" connected sims:");for(let r of n){let s=[r.isPrimary?"primary":null,r.readyState,r.userVisible===!1?"hidden":r.userVisible===!0?"visible":null,r.userFocused?"focused":null].filter(Boolean).join(", ");console.error(` ${r.id} (${s})`)}console.error(""),console.error(" pass a valid --sim id, or run `sootsim list` to see all sessions.")}var Ee={rn:"/rn",connectrn:"/rn","connect-rn":"/rn",clock:"/app/clock","native-ui":"/app/native-ui",tamagui:"/app/tamagui",settings:"/app/settings",photos:"/app/photos",camera:"/app/camera"};function v(t){return new Promise(o=>setTimeout(o,t))}function A(t){return t.trim()}function Q(t){try{let o=new URL(t),e=o.pathname.replace(/\/+$/,"")||"/";return o.searchParams.has("open")||o.searchParams.has("port")||o.searchParams.has("bundle")||o.searchParams.has("demo")||o.pathname.includes("/sootsim/index.html")||e==="/sootsim"||o.pathname==="/__soot"||o.pathname==="/__soot/"||e==="/rn"||/^\/rn\/[^/]+$/i.test(e)||/^\/app\/[^/]+$/i.test(e)||e==="/__soot/rn"||/^\/__soot\/rn\/[^/]+$/i.test(e)||/^\/__soot\/app\/[^/]+$/i.test(e)}catch{return!1}}function Oe(t){try{let o=new URL(t).pathname.replace(/\/+$/,"")||"/";return/^\/preview\/[^/]+$/.test(o)||/^\/build\/.+/.test(o)}catch{return!1}}async function xt(t){let o=A(t);return(await $e(o)).bundleUrl}function _e(t){try{let o=new URL(t.startsWith("http")?t:`http://${t}`),e=o.pathname||"/";if(e!=="/"&&e!==""||o.search||o.hash||!/^(localhost|127\.0\.0\.1|\[::1\]|::1)$/i.test(o.hostname))return null;let n=o.port?Number(o.port):o.protocol==="https:"?443:80;return Number.isFinite(n)&&n>0?n:null}catch{return null}}async function $e(t){let o=A(t),e=/^\d+$/.test(o)?Number(o):_e(o);if(e&&e>0){let n=await ce(e);if(n)return{bundleUrl:n.bundleUrl,port:n.port,framework:n.framework,projectName:n.projectName}}return he(o)}function Y(t){let o=t.replace(/\/+$/,"")||"/";return o==="/__soot"||o.startsWith("/__soot/")?"/__soot":""}function Le(t,o){let e=A(t),n=new URL(o),r=Y(n.pathname);return n.pathname=`${r}/rn`,n.searchParams.delete("bundle"),n.searchParams.delete("demo"),n.searchParams.delete("app"),n.searchParams.delete("open"),n.searchParams.delete("port"),/^\d+$/.test(e)?n.pathname=`${r}/rn/${e}`:(n.pathname=`${r}/rn`,n.searchParams.set("open",e)),n.toString()}function De(t){let o=A(t);return/^\d+$/.test(o)||/^https?:\/\//i.test(o)?!0:/^(localhost|127\.0\.0\.1|\[::1\]|[^/]+\.localhost):\d+(?:\/.*)?$/i.test(o)}async function Ae(t,o){let e=await $e(t),n=new URL(o),r=Y(n.pathname);return n.pathname=`${r}/rn`,n.searchParams.delete("open"),n.searchParams.delete("port"),n.searchParams.delete("demo"),n.searchParams.delete("app"),n.searchParams.set("bundle",e.bundleUrl),n.toString()}function Ne(t){return t.startsWith("~/")?V.join(Re.homedir(),t.slice(2)):V.isAbsolute(t)?t:V.resolve(process.cwd(),t)}function Fe(t){let o={};for(let e=0;e<t.length;e++){if(t[e]!=="--replace")continue;let n=t[e+1];n||(console.error(" sootsim open: --replace expects <module>=<file>"),process.exit(1));let r=n.indexOf("=");(r<=0||r===n.length-1)&&(console.error(" sootsim open: --replace expects <module>=<file>"),process.exit(1));let s=n.slice(0,r).trim(),a=Ne(n.slice(r+1).trim());ve.existsSync(a)||(console.error(` sootsim open: replacement file not found: ${a}`),process.exit(1)),o[s]={file:a},e++}return Object.keys(o).length>0?{modules:o}:void 0}function Ie(){let t=te();return oe(t)&&t.runtimePort>0?`http://localhost:${t.runtimePort}/`:ne}async function D(t,o=Ie()){if(!t)return new URL(o).toString();if(Q(t))return new URL(t).toString();let e=Ee[t.toLowerCase()];if(e){let n=new URL(o),r=Y(n.pathname);return n.pathname=`${r}${e}`,n.toString()}return De(t)?Ae(t,o):Le(t,o)}function be(t,o){let e=t?.url||t?.origin||o;try{let n=new URL(e);return n.searchParams.delete("bundle"),n.searchParams.delete("demo"),n.searchParams.delete("app"),n.searchParams.delete("open"),n.searchParams.delete("port"),n.searchParams.delete("inspectOpen"),n.toString()}catch{return o}}async function He(t,o,e){let n=new URL(await D(t,o));return n.searchParams.set("inspectOpen",e),n.toString()}async function Ke(t,o,e,n={}){let r=n.attempts??30,s=n.intervalMs??500,a=n.minNodeCount??10;for(let i=0;i<r;i++){let l=S(t,{commandTimeoutMs:o,simId:e,simIdSource:"flag"});try{let c=await l.send({type:"evaluate",code:"(async () => (await window.__sootsimTest?.getNodeCount()) || 0)()"});if(typeof c=="number"&&c>a)return{bridge:l,count:c}}catch{}l.close(),await v(s)}return null}function ze(t){if(!t)return null;try{let o=new URL(t);if(o.searchParams.has("bundle")){let e=o.searchParams.get("bundle")||"";try{let n=new URL(e),r=n.pathname.length>36?`...${n.pathname.slice(-36)}`:n.pathname;return`bundle ${n.host}${r}`}catch{return"bundle"}}return o.searchParams.has("port")?`connect :${o.searchParams.get("port")||""}`:o.searchParams.has("open")?`connect ${o.searchParams.get("open")||""}`:o.searchParams.has("demo")?`demo ${o.searchParams.get("demo")||"default"}`:o.pathname.includes("/sootsim/index.html")||o.pathname==="/sootsim/"||o.pathname==="/sootsim"?"embedded sootsim":null}catch{return null}}function je(t,o){if(t.length===0){console.log(" no sims connected");return}console.log(` connected sims (${t.length}):
|
|
3
|
-
`);for(let e of t){let n=e.lockedBy&&e.lockExpiresAt?`locked by ${e.lockedBy} (${Math.max(0,Math.round((e.lockExpiresAt-Date.now())/1e3))}s)`:"",r=[e.isPrimary?"primary":"",e.id===o?"selected":"",e.readyState,e.userVisible===!1?"hidden":e.userVisible===!0?"visible":"",e.attachedCliCount&&e.attachedCliCount>0?"in use":"",e.userFocused?"focused":"",n].filter(Boolean);console.log(` ${e.id}${r.length?` [${r.join(", ")}]`:""}`);let s=ze(e.url);if(s)console.log(` loaded: ${s}`);else if(e.url){let a=e.url.length>96?`${e.url.slice(0,93)}\u2026`:e.url;console.log(` url: ${a}`)}else e.origin&&console.log(` origin: ${e.origin}`);e.title&&console.log(` title: ${e.title}`),e.visibilityState&&e.visibilityState!=="visible"&&console.log(` visibility: ${e.visibilityState}`),console.log(` connected: ${ye(Date.now()-e.connectedAt)}`),e.lastActiveAt&&e.lastActiveAt>0&&console.log(` last active: ${ye(Date.now()-e.lastActiveAt)}`)}}function ye(t){let o=Math.max(0,Math.round(t/1e3));return o<60?`${o}s ago`:o<3600?`${Math.round(o/60)}m ago`:o<86400?`${Math.round(o/3600)}h ago`:`${Math.round(o/86400)}d ago`}async function L(t,o,e,n={}){let r=n.attempts??30,s=n.intervalMs??500;for(let a=0;a<r;a++){let i=S(t,{commandTimeoutMs:o});try{let c=(await i.listSims()).find(e);if(c)return c}catch{}finally{i.close()}await v(s)}return null}async function We(t,o,e,n={}){let r=n.attempts??20,s=n.intervalMs??250;for(let a=0;a<r;a++){let i=S(t,{commandTimeoutMs:o});try{let c=(await i.listSims()).find(d=>d.id===e);if(!c||c.readyState!=="open")return!0}catch{return!0}finally{i.close()}await v(s)}return!1}function qe(t){let o=t.meta;if(!o||o.sootsimHostDriver!=="playwright")return null;let e=Number(o.sootsimHostPid);return!Number.isInteger(e)||e<=1||e===process.pid?null:e}function Ge(t){if(!t.connectAckFile)return!1;try{return ve.writeFileSync(t.connectAckFile,`${JSON.stringify({connectedAt:Date.now(),pid:t.pid??null})}
|
|
4
|
-
`,{flag:"w"}),!0}catch{return!1}}function Se(t){try{return process.kill(t,0),!0}catch(o){return o?.code==="EPERM"}}async function Ve(t,o=2500){let e=Date.now()+o;for(;Date.now()<e;){if(!Se(t))return!0;await v(100)}return!Se(t)}async function J(t,o){let e=new Set(o),n=new Set;for(let r of t){if(!e.has(r.id))continue;let s=qe(r);s&&n.add(s)}for(let r of n){try{process.kill(r,"SIGTERM")}catch{}if(await Ve(r)){console.log(` closed playwright host process ${r}`);continue}try{process.kill(r,"SIGKILL"),console.log(` force-closed playwright host process ${r}`)}catch{}}}function N(t,o){if(o){let r=o.trim(),s=t.find(a=>a.id===r);if(!s)throw new Error(`no sim connected with id ${r}`);return s}let e=t.find(r=>r.isPrimary&&r.readyState==="open");if(e)return e;let n=t.find(r=>r.readyState==="open");if(n)return n;throw new Error("no sim connected")}function B(t,o,e){console.log(` ${e==="current sim"?"loaded":"opened"}: ${t} [${e}]`),console.log(` current sim: ${o.id}`),console.log(JSON.stringify({simId:o.id,url:o.url},null,2))}async function T(t,o,e){if(e.includes("--no-describe"))return;let n=process.env.SOOTSIM_QUIET_TARGET_NOTICE;process.env.SOOTSIM_QUIET_TARGET_NOTICE="1";try{await Je(t,o,{stableMs:150,maxMs:400});let r=S(t,{commandTimeoutMs:3e3,simId:o,cliLabel:"open --describe",simIdSource:"flag"});try{let s=null;try{s=await r.send({type:"evaluate",code:se})}catch{}if(s&&!(s.flag===!0&&!s.loadingText&&s.nodes>=ie&&ae(s))){let d=s.loadingText?`still showing "${s.loadingText}"`:s.flag!==!0?"guest ready event has not fired":s.targets<=0?"no visible app content is inspectable yet":"app tree is still stabilizing";console.log(` app still loading: ${d} (nodes: ${s.nodes}, targets: ${s.targets})`),console.log(" before interacting, run: sootsim wait ready --max-ms 120000")}let i=`(async () => {
|
|
5
|
-
const t = window.__sootsimTest
|
|
6
|
-
const ms = window.SootSim?.bridges?.mainShell
|
|
7
|
-
if (!t) return null
|
|
8
|
-
let shell = null
|
|
9
|
-
try { shell = ms?.getState ? await ms.getState() : null } catch {}
|
|
10
|
-
const tree = await t.dumpTree(12, ${JSON.stringify({describe:!0,verbose:!1,filter:""})})
|
|
11
|
-
return { tree, shell }
|
|
12
|
-
})()`,l=await r.send({type:"evaluate",code:i});if(!l?.tree)return;if(console.log(""),l.shell?.state){let c=[`state=${l.shell.state}`,l.shell.activeApp?`app=${l.shell.activeApp}`:null].filter(Boolean);console.log(` shell: ${c.join(" ")}`)}console.log(l.tree)}finally{r.close()}}catch{}finally{n===void 0?delete process.env.SOOTSIM_QUIET_TARGET_NOTICE:process.env.SOOTSIM_QUIET_TARGET_NOTICE=n}}async function Je(t,o,e){let n=Date.now()+e.maxMs,r="(async () => (await window.__sootsimTest?.getNodeCount?.()) || 0)()",s=S(t,{commandTimeoutMs:2e3,simId:o,simIdSource:"flag"});try{let a=-1,i=0;for(;Date.now()<n;){let l=-1;try{let c=await s.send({type:"evaluate",code:r});typeof c=="number"&&(l=c)}catch{}if(l>=0&&l===a){if(Date.now()-i>=e.stableMs)return}else a=l,i=Date.now();await v(50)}}finally{s.close()}}async function kt(t,o={}){let e=I(t,{port:o.port,commandTimeoutMs:o.timeoutMs}),n=x(e);try{let r=await n.listSims();je(r,e.simId)}finally{n.close()}}async function Pt(t,o={}){let e=I(t,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--new","--headless","--ephemeral"],stripValueFlags:["--base-url","--replace","--driver","--profile"]}),n=t.find((u,m)=>t[m-1]==="--profile"),r=t.includes("--ephemeral");n&&r&&(console.error(" sootsim open: --profile cannot be combined with --ephemeral"),process.exit(1));let s=n?de(n).id:void 0,a=!!s||r,i=t.includes("--new")||a,l=Fe(t);i&&e.simIdSource==="flag"&&(console.error(" sootsim open: --new, --profile, and --ephemeral cannot be combined with --sim"),process.exit(1));let c=e.positional[0]||"";if(Oe(c)){let u=(()=>{try{return/^(localhost|127\.0\.0\.1|\[::1\]|::1)$/i.test(new URL(c).hostname)}catch{return!1}})();console.log(" that\u2019s a SootSim preview/build link \u2014 a full player page, not a driveable sim."),console.log(" opening it in your browser for viewing\u2026");try{await z(c,{background:!1})}catch(m){console.error(` could not launch a browser: ${m instanceof Error?m.message:String(m)}`),console.error(` open it yourself: ${c}`),process.exit(1)}console.log(u?" to drive it under the CLI, point `sootsim open` at the app\u2019s dev port instead (e.g. `sootsim open 8081`).":" the CLI can\u2019t drive a remote preview (the engine only attaches to the local bridge from localhost). to drive the app, run it locally and `sootsim open <port>`.");return}let d=t.find((u,m)=>t[m-1]==="--driver")||"",p=t.includes("--headless"),h=t.find((u,m)=>t[m-1]==="--base-url")||Ie(),M=t.includes("--base-url"),X=k();if(!d&&!i&&(e.simIdSource==="flag"||e.simIdSource==="saved"&&!!X)){let u=x(e),m=e.simId?` --sim ${e.simId}`:"",f=!1;try{let g=null;try{let y=await u.listSims();if(e.simIdSource==="saved"?(g=y.find($=>$.id===X&&$.readyState==="open")??null,g||P()):g=N(y,e.simId),!g)if(e.simIdSource==="saved")f=!0;else throw new Error("no sim connected");if(!f&&g){let $=M||Q(c)?h:be(g,h),E=await D(c,_($,l));u.send({type:"evaluate",simId:g.id,code:`window.location.href = ${JSON.stringify(E)}`}).catch(()=>{})}}catch(y){console.error(` open failed: ${y instanceof Error?y.message:String(y)}`),await O(u,{errorsCommand:`sootsim get errors 5${m}`,warningsCommand:`sootsim get warnings 5${m}`,requestsCommand:`sootsim get requests 5${m}`}),process.exit(1)}if(!f&&g){await v(1500);let y=await Ke(e.wsPort,e.commandTimeoutMs,g.id);y||(console.error(" timed out waiting for current sim to load target"),process.exit(1)),y.bridge.close(),w(g.id);let $=M||Q(c)?h:be(g,h),E=await D(c,_($,l));B(E,{...g,url:E},"current sim"),await T(e.wsPort,g.id,t);return}}finally{u.close()}}let Z=_(h,l),ke=await D(c,Z),ee=`cli-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,b=await He(c,Z,ee),F={newWindow:!0},U=u=>u.url?.includes(`inspectOpen=${ee}`)??!1;if(d){let u=q(d);u||(console.error(` unknown driver "${d}" \u2014 run \`sootsim list --drivers\``),process.exit(1));let m=await u.launch({url:b,headless:p,newWindow:F.newWindow,profileId:s,ephemeralProfile:r});m.launched||(console.error(` ${u.name} driver: ${m.message}`),process.exit(1));let f=await L(e.wsPort,e.commandTimeoutMs,U,{attempts:60,intervalMs:500});if(!f){if(m.pid)try{process.kill(m.pid,"SIGTERM"),console.error(` closed ${u.name} host process ${m.pid}`)}catch{}console.error(" timed out waiting for opened sim to connect"),process.exit(1)}w(f.id),Ge(m),B(b,f,`${u.name} driver`),await T(e.wsPort,f.id,t);return}if(a){let u=C();u||(console.error(" profiles require electron or playwright; install the desktop companion or use `--driver playwright`"),process.exit(1));try{(await W(b,u,{profileId:s,ephemeralProfile:r})).launched||(console.error(" desktop companion failed to start"),process.exit(1))}catch(f){console.error(` desktop companion failed: ${f instanceof Error?f.message:String(f)}`),process.exit(1)}let m=await L(e.wsPort,e.commandTimeoutMs,U,{attempts:40,intervalMs:500});m||(console.error(" timed out waiting for profiled sim to connect"),process.exit(1)),w(m.id),B(b,m,"desktop companion"),await T(e.wsPort,m.id,t);return}let H=!1,K=!1;try{let u=S(e.wsPort,{commandTimeoutMs:2e3});try{await u.listSims(),H=!0}finally{u.close()}}catch{}if(H)try{let u=S(e.wsPort,{commandTimeoutMs:3e3});try{await u.openUrl(b,F),K=!0}finally{u.close()}}catch{}if(!K){let u=C();if(u)try{if((await W(b,u)).launched){let f=await L(e.wsPort,e.commandTimeoutMs,U,{attempts:20,intervalMs:500});if(f){w(f.id),B(b,f,"desktop companion"),await T(e.wsPort,f.id,t);return}}}catch{}try{await z(b,F)}catch(m){console.error(` open failed: ${m instanceof Error?m.message:String(m)}`),q("playwright")?.availability().available?console.error(" no system browser found \u2014 retry with `sootsim open \u2026 --driver playwright` for a headless sim."):console.error(" run `sootsim list --drivers` to see available drivers."),process.exit(1)}if(!H){console.log(` opened: ${ke}`),we(e.wsPort);return}}let R=await L(e.wsPort,e.commandTimeoutMs,U,{attempts:30,intervalMs:500});R||(console.error(" timed out waiting for opened sim to connect"),process.exit(1)),w(R.id),B(b,R,K?"bridge":"direct shell open"),await T(e.wsPort,R.id,t)}async function xe(t,o={}){let e=I(t,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--force"]}),n=t.includes("--force"),r=x(e),s=e.simId?` --sim ${e.simId}`:"";try{try{let a=await r.listSims(),i=N(a,e.positional[0]||e.simId);if(i.lockedBy&&i.lockExpiresAt&&i.lockExpiresAt>Date.now()){let l=Math.max(0,Math.round((i.lockExpiresAt-Date.now())/1e3));i.lockedByKind==="user-active"&&(console.error(` refused: ${i.id} is locked by the active user (${l}s) \u2014 that's a live human tab`),console.error(" run `sootsim open --new` for a fresh investigation sim"),process.exit(1)),n||(console.error(` refused: ${i.id} is leased by ${i.lockedBy} (${l}s)`),console.error(` \`sootsim use ${i.id} --force\` to take it, or \`sootsim open --new\` for a fresh sim`),process.exit(1))}await r.focusSim(i.id),w(i.id),console.log(` using: ${i.id}`)}catch(a){console.error(` use failed: ${a instanceof Error?a.message:String(a)}`),await O(r,{errorsCommand:`sootsim get errors 5${s}`,warningsCommand:`sootsim get warnings 5${s}`,requestsCommand:`sootsim get requests 5${s}`}),process.exit(1)}}finally{r.close()}}async function Ct(t,o={}){await xe(t,o)}async function Bt(t,o={}){await xe(t,o)}async function Tt(t,o={}){let e=I(t,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--force"]}),n=t.includes("--force"),r=x(e);try{try{let s=await r.listSims(),a=N(s,e.positional[0]||e.simId),i=n&&a.lockedBy&&a.lockedByKind!=="user-active"?a.lockedBy:null,l=await r.claim(a.id,{force:n});w(a.id);let c=Math.max(0,Math.round((l.lockExpiresAt-Date.now())/1e3)),d=l.bootedCount>0?` (booted ${l.bootedCount})`:"";console.log(` claimed: ${l.simId} [${c}s]${d}`),i&&console.log(` took over from: ${i}`)}catch(s){if(s instanceof re){let a=Math.max(0,Math.round(s.lock.expiresInMs/1e3));console.error(` claim failed: locked by ${s.lock.by} for ${a}s more`),console.error(" use --force to take it, or `sootsim open --new` for a fresh sim"),process.exit(1)}console.error(` claim failed: ${s instanceof Error?s.message:String(s)}`),process.exit(1)}}finally{r.close()}}async function Qe(t,o,e,n){if(n.length===0)return{closed:[],remaining:[]};await Promise.all(n.map(s=>t.closeSim(s).catch(()=>{})));let r=new Set(n);for(let s=0;s<40;s++){let a=[];try{let i=S(o,{commandTimeoutMs:e});try{a=(await i.listSims()).filter(c=>r.has(c.id)&&c.readyState==="open").map(c=>c.id)}finally{i.close()}}catch{a=[]}if(a.length===0)return{closed:[...r],remaining:[]};if(s===39)return{closed:[...r].filter(i=>!a.includes(i)),remaining:a};await v(250)}return{closed:[...r],remaining:[]}}function Ye(t,o){let e=t.filter(p=>p.readyState==="open"),n=e.map(p=>p.id),r=o.explicitKeepId?.trim()||"",s=o.savedKeepId?.trim()||"",a=s?e.some(p=>p.id===s):!1,i=s&&!a?s:null,l=null,c=null,d=null;if(o.closeOthers)if(r){let p=e.find(h=>h.id===r);p?l=p.id:c=r}else if(s&&a)l=s;else{let p=e.find(h=>h.isPrimary)??e[0]??null;p&&(l=p.id,s&&!a&&(d=p.id))}return{openIds:n,keepId:l,targets:c?[]:n.filter(p=>p!==l),staleSavedId:i,missingExplicitKeepId:c,fallbackKeepId:d}}async function Mt(t,o={}){let e=I(t,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--all","--others"]}),n=x(e),r=e.simId?` --sim ${e.simId}`:"",s=t.includes("--all"),a=t.includes("--others");if(s||a){try{let i=await n.listSims(),l=k(),c=e.positional[0]||(e.simIdSource==="flag"?e.simId:void 0),d=Ye(i,{closeOthers:a,explicitKeepId:c,savedKeepId:l});if(d.staleSavedId&&P(),d.fallbackKeepId&&(w(d.fallbackKeepId),console.log(` saved sim ${d.staleSavedId} is gone \u2014 keeping primary ${d.fallbackKeepId}`)),d.missingExplicitKeepId&&(console.error(` close failed: keep sim ${d.missingExplicitKeepId} is not connected; not closing other sims`),process.exit(1)),d.targets.length===0){console.log(d.keepId?` nothing to close \u2014 only the kept sim ${d.keepId} is connected`:d.staleSavedId?` nothing to close \u2014 no sims connected (cleared stale current sim ${d.staleSavedId})`:" nothing to close \u2014 no sims connected");return}let p=await Qe(n,e.wsPort,e.commandTimeoutMs,d.targets);await J(i,d.targets);let h=k();h&&p.closed.includes(h)&&(d.keepId?w(d.keepId):P());let M=` closed ${p.closed.length} sim(s)${d.keepId?` (kept ${d.keepId})`:""}`;console.log(M),p.remaining.length>0&&(console.error(` close failed: still connected: ${p.remaining.join(", ")}`),process.exit(1))}catch(i){console.error(` close failed: ${i instanceof Error?i.message:String(i)}`),process.exit(1)}finally{n.close()}return}try{try{let i=await n.listSims(),l=N(i,e.positional[0]||e.simId),c=i.find(p=>p.id!==l.id&&p.readyState==="open");await n.closeSim(l.id),await We(e.wsPort,e.commandTimeoutMs,l.id)||(await J(i,[l.id]),console.error(` close failed: ${l.id} is still connected`),process.exit(1)),await J(i,[l.id]),k()===l.id&&(c?w(c.id):P()),console.log(` closed: ${l.id}`)}catch(i){console.error(` close failed: ${i instanceof Error?i.message:String(i)}`),await O(n,{errorsCommand:`sootsim get errors 5${r}`,warningsCommand:`sootsim get warnings 5${r}`,requestsCommand:`sootsim get requests 5${r}`}),process.exit(1)}}finally{n.close()}}export{rt as a,Ue as b,st as c,xt as d,Ie as e,D as f,He as g,ze as h,je as i,L as j,qe as k,Ge as l,J as m,kt as n,Pt as o,Ct as p,Bt as q,Tt as r,Qe as s,Ye as t,Mt as u};
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
/*! sootsim v0.1.89 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
-
import{d as ae,e as le,f as ce}from"./chunk-OHEIXPMP.js";import{c as se,e as ie,g as B}from"./chunk-IVRX3TEH.js";import{d as oe}from"./chunk-PIRJFIZF.js";import{a as re,b as T}from"./chunk-LJXW33TJ.js";import{a as ne}from"./chunk-W5CC6JIX.js";import{createHash as Ee}from"crypto";import{readFileSync as D}from"fs";import{gzipSync as pe}from"zlib";function de(e){let t=(e||"").toLowerCase().split(";")[0].trim();return t?!(t.startsWith("image/")||t.startsWith("video/")||t.startsWith("audio/")||t==="font/woff2"||t==="application/font-woff2"||t==="application/zip"||t==="application/gzip"):!0}function V(e,t){let r=new AbortController,o=setTimeout(()=>r.abort(new Error(`${t} timed out after ${e/1e3}s`)),e);return{signal:r.signal,cancel:()=>clearTimeout(o)}}async function Se(e){let t=V(12e4,`PUT ${e.url}`),r;try{r=await fetch(e.url,{method:"PUT",headers:{"content-type":e.contentType},body:e.bytes,signal:t.signal})}finally{t.cancel()}if(!r.ok){let o=await r.text().catch(()=>"");throw new Error(`PUT ${e.url} failed ${r.status}: ${o.slice(0,200)}`)}}async function _e(e,t=8,r){let o=0,s=0,i=e.length;await Promise.all(Array.from({length:Math.min(t,i)},async()=>{for(;o<i;){let l=e[o++];await Se(l),s++,r?.(s,i)}}))}function $e(e,t,r,o){let s=[];s.push({url:e.bundle.putUrl,contentType:e.bundle.contentType,bytes:t});for(let i of e.files){let l=r.get(i.urlhash);l&&s.push({url:i.putUrl,contentType:i.contentType,bytes:l})}e.events&&o?.eventsBytes&&s.push({url:e.events.putUrl,contentType:e.events.contentType,bytes:o.eventsBytes}),e.flowVideo&&o?.videoBytes&&s.push({url:e.flowVideo.putUrl,contentType:e.flowVideo.contentType,bytes:o.videoBytes}),e.storage&&o?.storageBytes&&s.push({url:e.storage.putUrl,contentType:e.storage.contentType,bytes:o.storageBytes});for(let i of e.snapshots??[]){let l=o?.snapshotBytes?.get(i.id);l&&s.push({url:i.putUrl,contentType:i.contentType,bytes:l})}return s}function ke(e){return e.replace(/\/+$/,"")}var z=class extends Error{constructor(r,o,s,i=""){super(r);this.status=o;this.phase=s;this.responseText=i;this.name="PresignedUploadError"}};async function ue(e){let t=ke(e.originBase),r={"content-type":"application/json"};e.authHeader&&(r.authorization=e.authHeader),e.adminBypassToken&&(r["x-soot-admin-upload-bypass"]=e.adminBypassToken);let o=V(3e4,"init"),s;try{s=await fetch(`${t}/api/preview/upload/init`,{method:"POST",headers:r,body:JSON.stringify(e.initBody),signal:o.signal})}finally{o.cancel()}if(!s.ok){let p=await s.text().catch(()=>"");throw new z(`init failed: ${s.status} ${p.slice(0,200)}`,s.status,"init",p)}let i=await s.json(),l=$e(i,e.bundleBytes,e.filesByHash,e.extras);await _e(l,e.concurrency??8,e.onPutProgress);let h=V(3e4,"finalize"),d;try{d=await fetch(`${t}/api/preview/upload/finalize`,{method:"POST",headers:r,body:JSON.stringify({token:i.token}),signal:h.signal})}finally{h.cancel()}if(!d.ok){let p=await d.text().catch(()=>"");throw new z(`finalize failed: ${d.status} ${p.slice(0,200)}`,d.status,"finalize",p)}let S=await d.json();return{init:i,finalize:S}}function Le(e){if(!e)return null;try{let t=JSON.parse(e);return typeof t.message=="string"&&t.message?t.message:null}catch{return null}}var ye=process.env.SOOTSIM_UPLOAD_ORIGIN||"https://sootbean.com",me=process.env.SOOTSIM_PREVIEW_ORIGIN||"https://sootsim.com",j="http://localhost:3000";async function ze(e){if(e)return e;if(process.env.SOOTSIM_UPLOAD_ORIGIN)return process.env.SOOTSIM_UPLOAD_ORIGIN;try{let t=await fetch(`${j}/api/preview/upload/init`,{method:"OPTIONS"});if(t.ok||t.status===204||t.status===405)return j}catch{}return ye}function O(e){return e.replace(/\/$/,"")}function Ae(e){try{let r=new URL(e).hostname.replace(/^\[|\]$/g,"").toLowerCase();return r==="localhost"||r.endsWith(".localhost")||r==="0.0.0.0"||r==="::1"||/^127(?:\.\d{1,3}){3}$/.test(r)}catch{return!1}}function Fe(e){try{let t=new URL(e).hostname.toLowerCase();return t==="sootbean.com"||t.endsWith(".sootbean.com")}catch{return!1}}function Me(e,t){return t?O(t):process.env.SOOTSIM_PREVIEW_ORIGIN?O(process.env.SOOTSIM_PREVIEW_ORIGIN):Ae(e)?O(e):Fe(e)?O(me):O(e)}function He(){console.log(`
|
|
3
|
-
sootsim upload \u2014 publish the current recorded bundle as a /preview/<id> link
|
|
4
|
-
|
|
5
|
-
usage:
|
|
6
|
-
sootsim upload [--origin <url>] [--public-origin <url>] (--events <path> | --video <path>) [--screenshot <path>] [--owner <org> --repo <repo>] [--sim <sim>] [--open] [--assets-only]
|
|
7
|
-
|
|
8
|
-
options:
|
|
9
|
-
--origin <url> upload target (default: auto)
|
|
10
|
-
prefers ${j} when available, otherwise
|
|
11
|
-
falls back to ${ye}
|
|
12
|
-
override with SOOTSIM_UPLOAD_ORIGIN env var
|
|
13
|
-
--public-origin <url>
|
|
14
|
-
public /preview link origin (default: ${me}
|
|
15
|
-
for prod uploads, upload origin for localhost/custom origins).
|
|
16
|
-
override with SOOTSIM_PREVIEW_ORIGIN env var
|
|
17
|
-
--events <path> path to a gzipped events .jsonl.gz file to attach
|
|
18
|
-
required unless --video is present; previews must
|
|
19
|
-
have replay or recording playback data
|
|
20
|
-
--screenshot <path>
|
|
21
|
-
path to a PNG thumbnail to attach to the share
|
|
22
|
-
--video <path> path to a webm/mp4/gif flow recording. embedded inline
|
|
23
|
-
in the pr sticky comment served at
|
|
24
|
-
/api/preview/flow-video?id=<share-id>
|
|
25
|
-
--video-duration-ms <ms>
|
|
26
|
-
duration hint for attached flow video
|
|
27
|
-
--owner <org> associate a session upload with a linked org repo
|
|
28
|
-
--repo <repo> repo name for --owner; the signed-in user must belong
|
|
29
|
-
to the local/org team that owns the link
|
|
30
|
-
--sim <sim> target a specific sim (see: sootsim list)
|
|
31
|
-
--open open the resulting /preview/<id> url in the browser
|
|
32
|
-
--assets-only drop API/JSON/HTML records before upload; keep images,
|
|
33
|
-
fonts, css, js, and binary blobs. live-data demos hit
|
|
34
|
-
the real network at replay time instead of serving
|
|
35
|
-
recorded API snapshots
|
|
36
|
-
-h, --help
|
|
37
|
-
|
|
38
|
-
examples:
|
|
39
|
-
sootsim upload --events ./my-session.jsonl.gz
|
|
40
|
-
sootsim upload --origin http://localhost:3000 --events ./my-session.jsonl.gz --open
|
|
41
|
-
sootsim upload --video /tmp/soot-flow.webm --video-duration-ms 12000
|
|
42
|
-
`)}function w(e,t){let r=e.findIndex(s=>s===t);if(r<0)return;let o=e[r+1];return e.splice(r,2),o}function fe(e,t){let r=e.findIndex(o=>o===t);return r<0?!1:(e.splice(r,1),!0)}function ge(e){let t=(e||"").toLowerCase().split(";")[0].trim();return t?!!(t.startsWith("image/")||t.startsWith("font/")||t.startsWith("video/")||t.startsWith("audio/")||t.startsWith("model/")||t==="text/css"||t==="application/javascript"||t==="text/javascript"||t==="application/wasm"||t==="application/font-woff"||t==="application/font-woff2"||t==="application/octet-stream"):!1}async function he(e){let t=await fetch(e);if(!t.ok)throw new Error(`fetch ${e} -> ${t.status} ${t.statusText}`);return new Uint8Array(await t.arrayBuffer())}function Ne(e){return/\.bundle($|\?)/.test(e)||/\.js($|\?)/.test(e)?"application/javascript":/\.zip($|\?)/.test(e)?"application/zip":"application/javascript"}function Ce(e){try{let t=new URL(e);return t.searchParams.get("lazy")==="true"?(t.searchParams.set("lazy","false"),t.toString()):e}catch{return e}}async function We(e,t){let o=[];for(let s=0;s<t;s+=15e5){let i=Math.min(s+15e5,t),l=await B(e,`(window.__sootsimLastTransformedBundle?.text || "").slice(${s}, ${i})`);if(typeof l!="string")return null;o.push(l)}return o.join("")}function G(e){let t=new Map;for(let r of e)t.set(r.urlhash||r.url,r);return Array.from(t.values())}async function nt(e,t){(e.includes("--help")||e.includes("-h"))&&(He(),process.exit(0));let r=[...e],o=await ze(w(r,"--origin")),s=Me(o,w(r,"--public-origin")),i=w(r,"--events"),l=w(r,"--screenshot"),h=w(r,"--video"),d=w(r,"--video-duration-ms"),S=w(r,"--owner"),p=w(r,"--repo"),we=fe(r,"--open");(S&&!p||!S&&p)&&(console.error(" --owner and --repo must be provided together"),process.exit(1)),!i&&!h&&(console.error(" preview uploads require playback data: pass --events or --video.\n for a normal local preview, use `sootsim record --mode combined --open`\n or `sootsim flow --preview` instead of uploading a bundle-only snapshot."),process.exit(1));let J=fe(r,"--assets-only"),be=se(r,{stripBooleanFlags:[],stripValueFlags:[]}),b=ie(be),c,K=[],y=[],A=null;try{if(c=await B(b,'(typeof window.__sootsimCaptureBundle === "function") ? window.__sootsimCaptureBundle() : null'),c?.bundleUrl){let n=new URL(c.bundleUrl).origin,[a,C]=await Promise.all([B(b,`(window.__sootsimPreviewRecorder?.list?.(${JSON.stringify(n)}) || [])`),B(b,`(async () => {
|
|
43
|
-
const list = window.__sootsimListWorkerFetchRecorder
|
|
44
|
-
return typeof list === 'function'
|
|
45
|
-
? await list(${JSON.stringify(n)})
|
|
46
|
-
: []
|
|
47
|
-
})()`)]);K=G([...a,...C]).filter(u=>{try{return!new URL(u.url).pathname.startsWith("/api/")}catch{return!0}});let $=await B(b,`(async () => {
|
|
48
|
-
const rec = window.__sootsimPreviewRecorder
|
|
49
|
-
const workerList = window.__sootsimListWorkerFetchRecorder
|
|
50
|
-
return {
|
|
51
|
-
main: rec?.list ? rec.list() : [],
|
|
52
|
-
worker: typeof workerList === 'function' ? await workerList() : [],
|
|
53
|
-
}
|
|
54
|
-
})()`),R=($?G([...$.main,...$.worker]):[]).filter(u=>{try{return new URL(u.url).origin!==n}catch{return!1}}),U=R.length>0?{count:R.length,totalBytes:R.reduce((u,x)=>u+(x.size||0),0)}:null;if(U&&U.count>0){console.log(` ${U.count} recorded cross-origin responses (${(U.totalBytes/1024).toFixed(1)} KiB)`);let u=await B(b,`(async () => {
|
|
55
|
-
const rec = window.__sootsimPreviewRecorder
|
|
56
|
-
const workerDump = window.__sootsimDumpWorkerFetchRecorder
|
|
57
|
-
const bundleUrl = ${JSON.stringify(c.bundleUrl)}
|
|
58
|
-
const keep = (r) => {
|
|
59
|
-
try {
|
|
60
|
-
const u = new URL(r.url)
|
|
61
|
-
if (u.origin !== ${JSON.stringify(n)}) return true
|
|
62
|
-
// bundle-origin api responses came from the rewritten
|
|
63
|
-
// /__app-api proxy at record time (re-keyed by the
|
|
64
|
-
// recorder's unwrap step). they need bodies attached the
|
|
65
|
-
// same way as cross-origin records \u2014 direct re-fetch from
|
|
66
|
-
// the dev server lacks the bundle's session cookies.
|
|
67
|
-
if (r.url !== bundleUrl && u.pathname.startsWith('/api/')) return true
|
|
68
|
-
return false
|
|
69
|
-
} catch { return false }
|
|
70
|
-
}
|
|
71
|
-
return {
|
|
72
|
-
main: rec?.dump ? rec.dump().filter(keep) : [],
|
|
73
|
-
worker: typeof workerDump === 'function'
|
|
74
|
-
? (await workerDump()).filter(keep)
|
|
75
|
-
: [],
|
|
76
|
-
}
|
|
77
|
-
})()`);if(y=G([...u.main,...u.worker]),J){let x=y.length;y=y.filter(q=>ge(q.contentType));let W=U.totalBytes-y.reduce((q,Oe)=>q+(Oe.size||0),0);console.log(` --assets-only: kept ${y.length}/${x} records (dropped ${(W/1024).toFixed(1)} KiB of API responses)`)}}}c?.transformedBundle&&(A=await We(b,c.transformedBundle.byteLength))}finally{b.close()}c||(console.error(" could not read bundle snapshot \u2014 is sootsim running and is the bundle loaded?"),process.exit(2)),c.bundleUrl||(console.error(` no ?bundle= URL on the current sootsim tab.
|
|
78
|
-
open the app you want to share first (e.g. sootsim open 8082), then run upload.`),process.exit(2));let f,F=!1;if(A!==null)f=new TextEncoder().encode(A),F=!0,console.log(` using post-transform bundle: ${(f.byteLength/1024).toFixed(1)} KiB`);else{let n=Ce(c.bundleUrl);n!==c.bundleUrl&&console.log(" forcing lazy=false for self-contained bundle"),console.log(` capturing: ${n}`),f=await he(n),console.log(` main bundle: ${(f.byteLength/1024).toFixed(1)} KiB`)}let k=K.filter(n=>n.url!==c.bundleUrl);J&&(k=k.filter(n=>ge(n.contentType))),console.log(` fetching ${k.length} extra files\u2026`);let E=(await Promise.all(k.map(async n=>{try{let a=await he(n.url);return{...n,bytes:a}}catch(a){return console.error(` warning: failed to re-fetch ${n.url}: ${a instanceof Error?a.message:a}`),null}}))).filter(n=>!!n),ve=E.reduce((n,a)=>n+a.bytes.byteLength,0);console.log(` ${E.length} extra files: ${(ve/1024).toFixed(1)} KiB`);let v;i&&(v=D(i));let g;l&&(g=D(l),console.log(` attaching screenshot: ${(g.byteLength/1024).toFixed(1)} KiB`));let m,L,Y;if(h){if(m=D(h),L=h.endsWith(".mp4")?"video/mp4":h.endsWith(".gif")?"image/gif":"video/webm",d){let n=Number(d);(!Number.isFinite(n)||n<=0)&&(console.error(` invalid --video-duration-ms: ${d}`),await T(),process.exit(1)),Y=Math.round(n)}console.log(` attaching flow video: ${(m.byteLength/1024).toFixed(1)} KiB (${L})`)}let P=ae(),I=ce(P),Ue=ne();re({event:"preview_upload_started",identity:{userId:P?.kind==="session"?Ue?.user?.id??null:null,repoId:I?.repoId??null,installationId:I?.installationId??null},properties:{origin:o,hasAuth:!!P,authMode:P?.kind??"none",bundleBytes:f.byteLength,isTransformed:F,extraFiles:E.length,recordedFetches:y.length,hasEvents:!!v,hasScreenshot:!!g,hasVideo:!!m}}),P||(console.error(" preview uploads need auth."),console.error(" set SOOTSIM_API_KEY=sk_sootsim_..., run `sootsim login`, or use the soot github runner."),await T(),process.exit(1));let Te=le(P),Be=(()=>{try{return new URL(c.bundleUrl).origin}catch{return null}})(),Q=(n,a,C,$,te,R,U,u)=>{let x=de(R),W=x?pe(n):n;return{url:a,urlhash:C,method:$,bodyHash:te,requestVaryHash:u,contentType:R,responseHeaders:U,bytes:W,encoding:x?"gzip":void 0}},M=[...E.map(n=>Q(n.bytes,n.url,n.urlhash,"GET","-",n.contentType,n.responseHeaders,n.requestVaryHash)),...y.map(n=>Q(Buffer.from(n.bodyBase64,"base64"),n.url,n.urlhash,n.method||"GET",n.bodyHash||"-",n.contentType,n.responseHeaders,n.requestVaryHash))],H=pe(f),Pe=Ee("sha256").update(f).digest("hex");console.log(` bundle raw=${(f.byteLength/1024).toFixed(1)} KiB gz=${(H.byteLength/1024).toFixed(1)} KiB`);let Ie={contentHash:Pe,bundleSizeBytes:f.byteLength,bundleContentType:Ne(c.bundleUrl),bundleEncoding:"gzip",bundleOrigin:Be,entry:c.entry,isTransformed:F,deviceSpec:c.deviceSpec,installationId:I?.installationId??void 0,repoId:I?.repoId,owner:S??I?.owner,repo:p??I?.repo,files:M.map(n=>({url:n.url,urlhash:n.urlhash,method:n.method,bodyHash:n.bodyHash,contentType:n.contentType,responseHeaders:n.responseHeaders,requestVaryHash:n.requestVaryHash,encoding:n.encoding,sizeBytes:n.bytes.byteLength})),events:v?{sizeBytes:v.byteLength}:void 0,snapshots:g?[{id:"landing",label:"Landing",kind:"landing",t:0,contentType:"image/png",sizeBytes:g.byteLength}]:void 0,flowVideo:m&&L?{sizeBytes:m.byteLength,contentType:L,durationMs:Y}:void 0},X=new Map;for(let n of M)X.set(n.urlhash,n.bytes);let Z=new Map;g&&Z.set("landing",g);let Re=Date.now(),_=H.byteLength;for(let n of M)_+=n.bytes.byteLength;v&&(_+=v.byteLength),g&&(_+=g.byteLength),m&&(_+=m.byteLength);let xe=`${O(o)}/api/preview/upload/init`;console.log(` init: ${xe}`);let N;try{let n=await ue({originBase:o,initBody:Ie,bundleBytes:H,filesByHash:X,extras:{eventsBytes:v,videoBytes:m,snapshotBytes:Z},authHeader:Te,concurrency:16});N=n.finalize;let a=1+n.init.files.length+(n.init.events?1:0)+n.init.snapshots.length+(n.init.flowVideo?1:0);console.log(` PUT ${a} objects in ${Date.now()-Re}ms (${(_/1024).toFixed(1)} KiB)`)}catch(n){let a=n;a.phase==="init"&&a.status===401&&(console.error(" preview upload requires a valid login."),console.error(" run `sootsim login` and retry."),await T(),process.exit(1)),a.status===402&&(console.error(` ${Le(a.responseText)??"preview uploads require Personal, Team, or an active trial \u2014 upgrade from the billing dialog."}`),await T(),process.exit(1)),console.error(` ${a.message??`${a.phase??"upload"} failed: ${String(n)}`}`),await T(),process.exit(1)}let ee=`${s}${N.url}`;console.log(`
|
|
79
|
-
stored ${N.filesStored??0} extra files`),console.log(` preview: ${ee}`),we&&await oe(ee),await T()}export{ze as a,Me as b,nt as c};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
/*! sootsim v0.1.89 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|