sootsim 0.1.85 → 0.1.87
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 +4 -4
- package/dist-cli/chunks/{agent-T3DUH5YJ.js → agent-JVF2PSHI.js} +2 -2
- package/dist-cli/chunks/{agent-wrapper-NSBF4THI.js → agent-wrapper-F2F4AOBI.js} +2 -2
- package/dist-cli/chunks/{assert-X3F7TRCZ.js → assert-YYD6OU4X.js} +2 -2
- package/dist-cli/chunks/auto-bootstrap-NUDEO3WI.js +2 -0
- package/dist-cli/chunks/beta-KQR3AUDC.js +2 -0
- package/dist-cli/chunks/{chunk-EKXK3SWK.js → chunk-356M3TGV.js} +2 -2
- package/dist-cli/chunks/{chunk-Y5PLPEEU.js → chunk-4QWGWI5X.js} +2 -2
- package/dist-cli/chunks/{chunk-EFM53PZ5.js → chunk-5UEPOBEU.js} +1 -1
- package/dist-cli/chunks/{chunk-QLJNSOS7.js → chunk-6JITQIIF.js} +1 -1
- package/dist-cli/chunks/{chunk-DWTLRPEN.js → chunk-7KZTQHB3.js} +2 -2
- package/dist-cli/chunks/{chunk-OXOARRKR.js → chunk-7SX73XWN.js} +10 -10
- package/dist-cli/chunks/{chunk-5DIGWOY7.js → chunk-BDMAV7YE.js} +1 -1
- package/dist-cli/chunks/{chunk-CF2LPRXD.js → chunk-BGA7UNHQ.js} +2 -2
- package/dist-cli/chunks/{chunk-MAO7F5PH.js → chunk-BREFZK7S.js} +3 -3
- package/dist-cli/chunks/chunk-CIRLGKNJ.js +2 -0
- package/dist-cli/chunks/{chunk-KUSQ4NNJ.js → chunk-CQGEFQ2O.js} +1 -1
- package/dist-cli/chunks/{chunk-5S6D7K4L.js → chunk-F2V2RDSF.js} +2 -2
- package/dist-cli/chunks/chunk-FYFVAKLG.js +1 -0
- package/dist-cli/chunks/{chunk-E2QE5FFP.js → chunk-G4DPGAY7.js} +1 -1
- package/dist-cli/chunks/{chunk-5N3V7OCG.js → chunk-HSIKVDO7.js} +2 -2
- package/dist-cli/chunks/{chunk-RZHREO3M.js → chunk-HUL7SDXP.js} +2 -2
- package/dist-cli/chunks/{chunk-HQDJ5BOF.js → chunk-IFTNXJFC.js} +1 -1
- package/dist-cli/chunks/{chunk-OISHLFON.js → chunk-JIGBO7T2.js} +1 -1
- package/dist-cli/chunks/{chunk-NVTL3JQG.js → chunk-JNC2KM5L.js} +1 -1
- package/dist-cli/chunks/{chunk-ZO3VHP6W.js → chunk-KHCGD2SK.js} +22 -10
- package/dist-cli/chunks/chunk-KOJH7M2Y.js +24 -0
- package/dist-cli/chunks/{chunk-BZL6D4TV.js → chunk-KRG3TVPS.js} +63 -62
- package/dist-cli/chunks/{chunk-OUNLJM56.js → chunk-L7NMKMAC.js} +2 -2
- package/dist-cli/chunks/{chunk-4EVSIUNB.js → chunk-LAFA2UUY.js} +2 -2
- package/dist-cli/chunks/{chunk-SBGOUA6F.js → chunk-LKF24E4V.js} +2 -2
- package/dist-cli/chunks/{chunk-AFNDVS4E.js → chunk-MAFNPEGR.js} +2 -2
- package/dist-cli/chunks/{chunk-GTAD6IUV.js → chunk-MDZ6HMDB.js} +1 -1
- package/dist-cli/chunks/chunk-NNBW2HSI.js +1 -0
- package/dist-cli/chunks/{chunk-EBEL6TTJ.js → chunk-OB6UTULM.js} +2 -2
- package/dist-cli/chunks/{chunk-7LKUN46F.js → chunk-OOMEG6UD.js} +2 -2
- package/dist-cli/chunks/{chunk-UYRGCJ4N.js → chunk-P7TSRSCR.js} +45 -45
- package/dist-cli/chunks/{chunk-BESAZ2HA.js → chunk-PJA4MECT.js} +2 -2
- package/dist-cli/chunks/{chunk-4QZHZ6BC.js → chunk-PQ64ESHO.js} +2 -2
- package/dist-cli/chunks/{chunk-AC6QGW22.js → chunk-PQIWV724.js} +2 -2
- package/dist-cli/chunks/{chunk-H44IQHKZ.js → chunk-PRQGETWQ.js} +1 -1
- package/dist-cli/chunks/{chunk-BHZJ6RIH.js → chunk-PV7UPMMH.js} +2 -2
- package/dist-cli/chunks/{chunk-PHPXGLME.js → chunk-QFHW7D44.js} +1 -1
- package/dist-cli/chunks/{chunk-O6N2CEET.js → chunk-QI3CAQIS.js} +2 -2
- package/dist-cli/chunks/{chunk-G7CIZ5S3.js → chunk-RFES5JTB.js} +3 -3
- package/dist-cli/chunks/chunk-SFGIFF2S.js +2 -0
- package/dist-cli/chunks/chunk-TRLVCBYL.js +1 -0
- package/dist-cli/chunks/{chunk-WGDL5V6C.js → chunk-Y2H2L6L7.js} +1 -1
- package/dist-cli/chunks/{chunk-3WGHC7JN.js → chunk-ZKJ42ZMK.js} +2 -2
- package/dist-cli/chunks/cli-version-QYZHMOJT.js +2 -0
- package/dist-cli/chunks/{compat-PCXGGZBZ.js → compat-46LSYJLF.js} +3 -3
- package/dist-cli/chunks/{config-LULEVEYL.js → config-P5NLMUL2.js} +2 -2
- package/dist-cli/chunks/{control-6P6HY7UF.js → control-3O7JEUFC.js} +2 -2
- package/dist-cli/chunks/{cpu-profile-NOK73ZYW.js → cpu-profile-LDMMDC7S.js} +2 -2
- package/dist-cli/chunks/{daemon-4A3DMUYL.js → daemon-BL3MXXR3.js} +3 -3
- package/dist-cli/chunks/{debug-74BWB2ZG.js → debug-SQA6GG37.js} +3 -3
- package/dist-cli/chunks/{detox-HEOMINSC.js → detox-TY6AOSA7.js} +2 -2
- package/dist-cli/chunks/{device-TTXXBJFZ.js → device-QWFX4556.js} +2 -2
- package/dist-cli/chunks/{diagnose-QZ3GOHSE.js → diagnose-P2UVBUN6.js} +2 -2
- package/dist-cli/chunks/drivers-HPRXOC6D.js +2 -0
- package/dist-cli/chunks/{electron-QVOWV44R.js → electron-U3KDMBJM.js} +3 -3
- package/dist-cli/chunks/flow-XGMUH4JT.js +2 -0
- package/dist-cli/chunks/help-HZCKWAH5.js +2 -0
- package/dist-cli/chunks/{hints-YKWRNMJC.js → hints-2IYL3NF4.js} +2 -2
- package/dist-cli/chunks/{home-paths-SFADSTJM.js → home-paths-5SZOYDCC.js} +2 -2
- package/dist-cli/chunks/{inspect-LEWGQCIU.js → inspect-FA4L7WIE.js} +107 -107
- package/dist-cli/chunks/install-SYVS2T2T.js +2 -0
- package/dist-cli/chunks/{install-desktop-22HYQZ2G.js → install-desktop-OLT6LS5L.js} +3 -3
- package/dist-cli/chunks/{keys-3ZT3MICU.js → keys-3OXB23J4.js} +2 -2
- package/dist-cli/chunks/{launch-ZXW2NFLG.js → launch-HEXKSA3X.js} +3 -3
- package/dist-cli/chunks/{login-NJKJ7GZO.js → login-DKQYESDF.js} +4 -4
- package/dist-cli/chunks/{logout-VMMQL7CB.js → logout-FMJJ3BR2.js} +2 -2
- package/dist-cli/chunks/{maestro-OJY4MTI7.js → maestro-Z24ESGQW.js} +2 -2
- package/dist-cli/chunks/{preview-QU2GXTEV.js → preview-ODKBHTV5.js} +2 -2
- package/dist-cli/chunks/{profile-7APWK47T.js → profile-2PIY7B3L.js} +2 -2
- package/dist-cli/chunks/{react-RSVO5JZZ.js → react-HL4CHJS4.js} +2 -2
- package/dist-cli/chunks/{record-UWH4MDEO.js → record-4LYFSZUK.js} +2 -2
- package/dist-cli/chunks/runtime-JML6VARG.js +2 -0
- package/dist-cli/chunks/{runtime-delivery-QMKGRV7N.js → runtime-delivery-U7WIYI7J.js} +2 -2
- package/dist-cli/chunks/{screenshot-43M27ALE.js → screenshot-YUA2BHDF.js} +2 -2
- package/dist-cli/chunks/{screenshot-mode-EBYYN6TY.js → screenshot-mode-UIL75CHP.js} +2 -2
- package/dist-cli/chunks/{screenshots-7TQZL6Z6.js → screenshots-YJWODQGP.js} +2 -2
- package/dist-cli/chunks/server-J644PTIB.js +40 -0
- package/dist-cli/chunks/setup-repo-GSEZY74V.js +2 -0
- package/dist-cli/chunks/{skills-RQA6EJQL.js → skills-PEBZZZTL.js} +2 -2
- package/dist-cli/chunks/{start-ZT6MBYND.js → start-JCJQRDDQ.js} +4 -4
- package/dist-cli/chunks/store-XGTUSOGS.js +2 -0
- package/dist-cli/chunks/telemetry-Y3IESY7P.js +2 -0
- package/dist-cli/chunks/{test-RNRX5SWV.js → test-Z3NU6IN7.js} +3 -3
- package/dist-cli/chunks/{three-mode-TQZH25ZO.js → three-mode-CFSZ2ZOW.js} +2 -2
- package/dist-cli/chunks/{timeline-GGN3AY6P.js → timeline-GEND6OI3.js} +2 -2
- package/dist-cli/chunks/{upgrade-XT22D67C.js → upgrade-6GFR2ZB7.js} +3 -3
- package/dist-cli/chunks/upload-OPMPP35I.js +2 -0
- package/dist-cli/chunks/{web-KEHVF5MB.js → web-7A27OUAC.js} +2 -2
- package/dist-cli/chunks/{what-happened-PATQRJ5T.js → what-happened-57G5T2GM.js} +2 -2
- package/dist-cli/chunks/{whoami-CXVY26VV.js → whoami-3ICC26FV.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 +15 -0
- 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 +244 -35
- package/dist-lib/host/fetch-proxy-handler.cjs +24 -4
- package/dist-lib/host/fetch-proxy-overrides.cjs +1 -1
- package/dist-lib/host/fetch-proxy-overrides.mjs +33 -0
- package/dist-lib/host/websocket-proxy.cjs +207 -0
- 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 +14 -3
- package/dist-lib/scripts/dev-server-scanner.cjs +14 -3
- package/dist-lib/skills.cjs +290 -73
- package/dist-lib/vite.cjs +1 -1
- package/package.json +7 -1
- package/scripts/demo-app-registry.ts +17 -1
- package/src/host/bridge-host.ts +8 -1
- package/src/host/fetch-proxy-handler.ts +26 -3
- package/src/host/websocket-proxy.ts +201 -0
- package/dist-cli/chunks/auto-bootstrap-47RN2V5G.js +0 -2
- package/dist-cli/chunks/beta-BRCGAF2N.js +0 -2
- package/dist-cli/chunks/chunk-36RPD6JI.js +0 -2
- package/dist-cli/chunks/chunk-4DBPNLGI.js +0 -1
- package/dist-cli/chunks/chunk-PQFFUJR6.js +0 -24
- package/dist-cli/chunks/chunk-QQAECG5B.js +0 -2
- package/dist-cli/chunks/chunk-SSCA2AEA.js +0 -1
- package/dist-cli/chunks/chunk-ZFAM4N5B.js +0 -1
- package/dist-cli/chunks/cli-version-WPFDM2A6.js +0 -2
- package/dist-cli/chunks/drivers-QRPWNOIT.js +0 -2
- package/dist-cli/chunks/flow-QMA7GVN6.js +0 -2
- package/dist-cli/chunks/install-7N2N7Q32.js +0 -2
- package/dist-cli/chunks/runtime-3FUENRHM.js +0 -2
- package/dist-cli/chunks/server-VCFM25Z6.js +0 -35
- package/dist-cli/chunks/setup-repo-HFH4VKJQ.js +0 -2
- package/dist-cli/chunks/store-BJBTDSZE.js +0 -2
- package/dist-cli/chunks/telemetry-ZZZKTILZ.js +0 -2
- package/dist-cli/chunks/upload-NC2AYLC5.js +0 -2
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.87 | (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;
|
|
@@ -32,6 +32,7 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
32
32
|
// src/host/fetch-proxy-handler.ts
|
|
33
33
|
var fetch_proxy_handler_exports = {};
|
|
34
34
|
__export(fetch_proxy_handler_exports, {
|
|
35
|
+
buildAppApiProxyHeaders: () => buildAppApiProxyHeaders,
|
|
35
36
|
buildFetchProxyHeaders: () => buildFetchProxyHeaders,
|
|
36
37
|
handleAppApiRequest: () => handleAppApiRequest,
|
|
37
38
|
handleFetchProxyRequest: () => handleFetchProxyRequest,
|
|
@@ -97,6 +98,14 @@ var FETCH_PROXY_CORS_HEADERS = {
|
|
|
97
98
|
"access-control-expose-headers": "*",
|
|
98
99
|
"access-control-max-age": "3600"
|
|
99
100
|
};
|
|
101
|
+
var APP_API_HEADER_REWRITES = /* @__PURE__ */ new Set([
|
|
102
|
+
"host",
|
|
103
|
+
"origin",
|
|
104
|
+
"referer",
|
|
105
|
+
"sec-fetch-site",
|
|
106
|
+
"sec-fetch-mode",
|
|
107
|
+
"sec-fetch-dest"
|
|
108
|
+
]);
|
|
100
109
|
function applyFetchProxyCors(res) {
|
|
101
110
|
for (const [key, value] of Object.entries(FETCH_PROXY_CORS_HEADERS)) {
|
|
102
111
|
res.setHeader(key, value);
|
|
@@ -129,6 +138,18 @@ function buildFetchProxyHeaders(reqHeaders, targetUrl) {
|
|
|
129
138
|
);
|
|
130
139
|
return headers;
|
|
131
140
|
}
|
|
141
|
+
function buildAppApiProxyHeaders(reqHeaders, targetUrl) {
|
|
142
|
+
const headers = {};
|
|
143
|
+
for (const [key, value] of Object.entries(reqHeaders)) {
|
|
144
|
+
if (!value) continue;
|
|
145
|
+
if (APP_API_HEADER_REWRITES.has(key.toLowerCase())) continue;
|
|
146
|
+
headers[key] = value;
|
|
147
|
+
}
|
|
148
|
+
headers.host = targetUrl.host;
|
|
149
|
+
headers.origin = targetUrl.origin;
|
|
150
|
+
headers.referer = `${targetUrl.origin}/`;
|
|
151
|
+
return headers;
|
|
152
|
+
}
|
|
132
153
|
function isFetchProxyRequestUrl(rawUrl) {
|
|
133
154
|
return rawUrl?.startsWith("/__fetch-proxy?") || rawUrl?.startsWith("/__proxy?") || false;
|
|
134
155
|
}
|
|
@@ -239,9 +260,7 @@ function handleAppApiRequest(req, res) {
|
|
|
239
260
|
return true;
|
|
240
261
|
}
|
|
241
262
|
const transport = targetUrl.protocol === "https:" ? import_https.default : import_http.default;
|
|
242
|
-
const fwdHeaders =
|
|
243
|
-
delete fwdHeaders.host;
|
|
244
|
-
fwdHeaders.host = targetUrl.host;
|
|
263
|
+
const fwdHeaders = buildAppApiProxyHeaders(req.headers, targetUrl);
|
|
245
264
|
const proxyReq = transport.request(
|
|
246
265
|
{
|
|
247
266
|
hostname: targetUrl.hostname,
|
|
@@ -273,6 +292,7 @@ function handleAppApiRequest(req, res) {
|
|
|
273
292
|
}
|
|
274
293
|
// Annotate the CommonJS export names for ESM import in node:
|
|
275
294
|
0 && (module.exports = {
|
|
295
|
+
buildAppApiProxyHeaders,
|
|
276
296
|
buildFetchProxyHeaders,
|
|
277
297
|
handleAppApiRequest,
|
|
278
298
|
handleFetchProxyRequest,
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.87 | (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;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/*! sootsim v0.1.87 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
+
|
|
3
|
+
// src/host/fetch-proxy-overrides.ts
|
|
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";
|
|
5
|
+
var HOST_HEADER_OVERRIDES = [
|
|
6
|
+
{
|
|
7
|
+
hostSuffix: "uniswap.org",
|
|
8
|
+
headers: {
|
|
9
|
+
origin: "https://app.uniswap.org",
|
|
10
|
+
referer: "https://app.uniswap.org/"
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
];
|
|
14
|
+
function headerOverridesFor(hostname) {
|
|
15
|
+
const host = hostname.toLowerCase();
|
|
16
|
+
for (const override of HOST_HEADER_OVERRIDES) {
|
|
17
|
+
if (host === override.hostSuffix || host.endsWith(`.${override.hostSuffix}`)) {
|
|
18
|
+
return override.headers;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return {};
|
|
22
|
+
}
|
|
23
|
+
function getFetchProxyTargetHeaders(targetUrl) {
|
|
24
|
+
return {
|
|
25
|
+
"accept-encoding": "identity",
|
|
26
|
+
"user-agent": FETCH_PROXY_BROWSER_USER_AGENT,
|
|
27
|
+
...headerOverridesFor(targetUrl.hostname)
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
export {
|
|
31
|
+
FETCH_PROXY_BROWSER_USER_AGENT,
|
|
32
|
+
getFetchProxyTargetHeaders
|
|
33
|
+
};
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
/*! sootsim v0.1.87 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
|
|
2
|
+
let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
|
|
3
|
+
"use strict";
|
|
4
|
+
var __defProp = Object.defineProperty;
|
|
5
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
21
|
+
|
|
22
|
+
// src/host/websocket-proxy.ts
|
|
23
|
+
var websocket_proxy_exports = {};
|
|
24
|
+
__export(websocket_proxy_exports, {
|
|
25
|
+
WEBSOCKET_PROXY_PATH: () => WEBSOCKET_PROXY_PATH,
|
|
26
|
+
handleWebSocketProxyUpgrade: () => handleWebSocketProxyUpgrade,
|
|
27
|
+
isWebSocketProxyRequestUrl: () => isWebSocketProxyRequestUrl
|
|
28
|
+
});
|
|
29
|
+
module.exports = __toCommonJS(websocket_proxy_exports);
|
|
30
|
+
var import_ws = require("ws");
|
|
31
|
+
var WEBSOCKET_PROXY_PATH = "/__websocket-proxy";
|
|
32
|
+
var STRIP_UPSTREAM_HEADERS = /* @__PURE__ */ new Set([
|
|
33
|
+
"host",
|
|
34
|
+
"connection",
|
|
35
|
+
"upgrade",
|
|
36
|
+
"transfer-encoding",
|
|
37
|
+
"content-length",
|
|
38
|
+
"sec-websocket-accept",
|
|
39
|
+
"sec-websocket-extensions",
|
|
40
|
+
"sec-websocket-key",
|
|
41
|
+
"sec-websocket-protocol",
|
|
42
|
+
"sec-websocket-version"
|
|
43
|
+
]);
|
|
44
|
+
function rejectUpgrade(socket, status, message) {
|
|
45
|
+
try {
|
|
46
|
+
socket.write(
|
|
47
|
+
`HTTP/1.1 ${status} ${message}\r
|
|
48
|
+
Connection: close\r
|
|
49
|
+
Content-Type: text/plain\r
|
|
50
|
+
Content-Length: ${message.length}\r
|
|
51
|
+
\r
|
|
52
|
+
${message}`
|
|
53
|
+
);
|
|
54
|
+
} catch {
|
|
55
|
+
}
|
|
56
|
+
socket.destroy();
|
|
57
|
+
}
|
|
58
|
+
function isSameOriginUpgrade(req) {
|
|
59
|
+
const origin = req.headers.origin;
|
|
60
|
+
const host = req.headers.host;
|
|
61
|
+
if (!origin || !host) return false;
|
|
62
|
+
try {
|
|
63
|
+
return new URL(origin).host === host;
|
|
64
|
+
} catch {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
function decodeProxyHeaders(encoded) {
|
|
69
|
+
if (!encoded) return {};
|
|
70
|
+
const base64 = encoded.replace(/-/g, "+").replace(/_/g, "/");
|
|
71
|
+
const padded = base64 + "=".repeat((4 - base64.length % 4) % 4);
|
|
72
|
+
const parsed = JSON.parse(Buffer.from(padded, "base64").toString("utf8"));
|
|
73
|
+
if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) return {};
|
|
74
|
+
const headers = {};
|
|
75
|
+
for (const [key, value] of Object.entries(parsed)) {
|
|
76
|
+
if (value == null) continue;
|
|
77
|
+
if (STRIP_UPSTREAM_HEADERS.has(key.toLowerCase())) continue;
|
|
78
|
+
headers[key] = Array.isArray(value) ? value.join(", ") : String(value);
|
|
79
|
+
}
|
|
80
|
+
return headers;
|
|
81
|
+
}
|
|
82
|
+
function getDefaultWebSocketOrigin(targetUrl) {
|
|
83
|
+
const origin = new URL(targetUrl.href);
|
|
84
|
+
origin.protocol = targetUrl.protocol === "wss:" ? "https:" : "http:";
|
|
85
|
+
return origin.origin;
|
|
86
|
+
}
|
|
87
|
+
function getRequestedProtocols(req) {
|
|
88
|
+
const header = req.headers["sec-websocket-protocol"];
|
|
89
|
+
const value = Array.isArray(header) ? header.join(",") : header || "";
|
|
90
|
+
return value.split(",").map((part) => part.trim()).filter(Boolean);
|
|
91
|
+
}
|
|
92
|
+
function safeClose(ws, code, reason) {
|
|
93
|
+
if (ws.readyState === import_ws.WebSocket.CLOSED || ws.readyState === import_ws.WebSocket.CLOSING) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
try {
|
|
97
|
+
ws.close(code, reason);
|
|
98
|
+
} catch {
|
|
99
|
+
ws.terminate();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
function connectProxyPair(clientWs, upstream) {
|
|
103
|
+
let closing = false;
|
|
104
|
+
const closeBoth = (source, target, code, reason) => {
|
|
105
|
+
if (closing) return;
|
|
106
|
+
closing = true;
|
|
107
|
+
safeClose(target, code, reason.toString());
|
|
108
|
+
if (source.readyState === import_ws.WebSocket.OPEN) {
|
|
109
|
+
safeClose(source, code, reason.toString());
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
clientWs.on("message", (data, isBinary) => {
|
|
113
|
+
if (upstream.readyState === import_ws.WebSocket.OPEN) {
|
|
114
|
+
upstream.send(data, { binary: isBinary });
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
upstream.on("message", (data, isBinary) => {
|
|
118
|
+
if (clientWs.readyState === import_ws.WebSocket.OPEN) {
|
|
119
|
+
clientWs.send(data, { binary: isBinary });
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
clientWs.on("close", (code, reason) => closeBoth(clientWs, upstream, code, reason));
|
|
123
|
+
upstream.on("close", (code, reason) => closeBoth(upstream, clientWs, code, reason));
|
|
124
|
+
clientWs.on("error", () => safeClose(upstream, 1011, "proxy client error"));
|
|
125
|
+
upstream.on("error", () => safeClose(clientWs, 1011, "upstream websocket error"));
|
|
126
|
+
}
|
|
127
|
+
function createUpstreamWebSocket(targetUrl, protocols, headers) {
|
|
128
|
+
const upstreamHeaders = { ...headers };
|
|
129
|
+
if (!Object.keys(upstreamHeaders).some((key) => key.toLowerCase() === "origin")) {
|
|
130
|
+
upstreamHeaders.origin = getDefaultWebSocketOrigin(targetUrl);
|
|
131
|
+
}
|
|
132
|
+
return new import_ws.WebSocket(targetUrl.href, protocols, {
|
|
133
|
+
headers: upstreamHeaders
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
function isWebSocketProxyRequestUrl(rawUrl) {
|
|
137
|
+
if (!rawUrl) return false;
|
|
138
|
+
try {
|
|
139
|
+
return new URL(rawUrl, "http://localhost").pathname === WEBSOCKET_PROXY_PATH;
|
|
140
|
+
} catch {
|
|
141
|
+
return false;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
function handleWebSocketProxyUpgrade(req, socket, head) {
|
|
145
|
+
if (!isWebSocketProxyRequestUrl(req.url)) return false;
|
|
146
|
+
if (!isSameOriginUpgrade(req)) {
|
|
147
|
+
rejectUpgrade(socket, 403, "forbidden websocket proxy origin");
|
|
148
|
+
return true;
|
|
149
|
+
}
|
|
150
|
+
let targetUrl;
|
|
151
|
+
let headers;
|
|
152
|
+
try {
|
|
153
|
+
const requestUrl = new URL(req.url || "/", "http://localhost");
|
|
154
|
+
const target = requestUrl.searchParams.get("url");
|
|
155
|
+
if (!target) {
|
|
156
|
+
rejectUpgrade(socket, 400, "missing websocket proxy url");
|
|
157
|
+
return true;
|
|
158
|
+
}
|
|
159
|
+
targetUrl = new URL(target);
|
|
160
|
+
if (targetUrl.protocol !== "ws:" && targetUrl.protocol !== "wss:") {
|
|
161
|
+
rejectUpgrade(socket, 400, "invalid websocket proxy protocol");
|
|
162
|
+
return true;
|
|
163
|
+
}
|
|
164
|
+
headers = decodeProxyHeaders(requestUrl.searchParams.get("headers"));
|
|
165
|
+
} catch {
|
|
166
|
+
rejectUpgrade(socket, 400, "invalid websocket proxy request");
|
|
167
|
+
return true;
|
|
168
|
+
}
|
|
169
|
+
const protocols = getRequestedProtocols(req);
|
|
170
|
+
const upstream = createUpstreamWebSocket(targetUrl, protocols, headers);
|
|
171
|
+
let completed = false;
|
|
172
|
+
socket.once("close", () => {
|
|
173
|
+
if (!completed) upstream.terminate();
|
|
174
|
+
});
|
|
175
|
+
upstream.once("open", () => {
|
|
176
|
+
if (completed) return;
|
|
177
|
+
completed = true;
|
|
178
|
+
const selectedProtocol = upstream.protocol;
|
|
179
|
+
const proxyServer = new import_ws.WebSocketServer({
|
|
180
|
+
noServer: true,
|
|
181
|
+
clientTracking: false,
|
|
182
|
+
handleProtocols(requestedProtocols) {
|
|
183
|
+
return selectedProtocol || requestedProtocols.values().next().value || false;
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
proxyServer.handleUpgrade(req, socket, head, (clientWs) => {
|
|
187
|
+
connectProxyPair(clientWs, upstream);
|
|
188
|
+
});
|
|
189
|
+
});
|
|
190
|
+
upstream.once("error", () => {
|
|
191
|
+
if (completed) return;
|
|
192
|
+
completed = true;
|
|
193
|
+
rejectUpgrade(socket, 502, "upstream websocket error");
|
|
194
|
+
});
|
|
195
|
+
upstream.once("close", () => {
|
|
196
|
+
if (completed) return;
|
|
197
|
+
completed = true;
|
|
198
|
+
rejectUpgrade(socket, 502, "upstream websocket closed");
|
|
199
|
+
});
|
|
200
|
+
return true;
|
|
201
|
+
}
|
|
202
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
203
|
+
0 && (module.exports = {
|
|
204
|
+
WEBSOCKET_PROXY_PATH,
|
|
205
|
+
handleWebSocketProxyUpgrade,
|
|
206
|
+
isWebSocketProxyRequestUrl
|
|
207
|
+
});
|
package/dist-lib/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.87 | (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.87 | (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.87 | (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.87 | (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.87 | (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;
|
|
@@ -593,11 +593,22 @@ var APPS = [
|
|
|
593
593
|
// be holding pglite locks on ~/takeout/.orez (soot can attach takeout as
|
|
594
594
|
// a project and spin up its own orez against the same data dir).
|
|
595
595
|
readyTimeoutMs: 24e4,
|
|
596
|
+
managedPorts: (p) => {
|
|
597
|
+
const offset = p - 8081;
|
|
598
|
+
return [5433 + offset, 4848 + offset, 9200 + offset];
|
|
599
|
+
},
|
|
596
600
|
command: (p) => ({
|
|
597
|
-
cmd: "bun lite",
|
|
601
|
+
cmd: "bun lite:demo",
|
|
598
602
|
env: {
|
|
603
|
+
TAKEOUT_ENV_MODE: "development",
|
|
599
604
|
PORT_OFFSET: String(p - 8081),
|
|
600
|
-
OREZ_DATA_DIR: `${HOME}/.cache/sootsim-demo/takeout-orez
|
|
605
|
+
OREZ_DATA_DIR: `${HOME}/.cache/sootsim-demo/takeout-orez`,
|
|
606
|
+
VITE_DEMO_MODE: "1",
|
|
607
|
+
ZERO_APP_ID: "takeout",
|
|
608
|
+
ZERO_APP_PUBLICATIONS: "zero_takeout",
|
|
609
|
+
ZERO_CVR_MAX_CONNS: "4",
|
|
610
|
+
ZERO_NUM_SYNC_WORKERS: "2",
|
|
611
|
+
ZERO_UPSTREAM_MAX_CONNS: "8"
|
|
601
612
|
}
|
|
602
613
|
})
|
|
603
614
|
},
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
1
|
+
/*! sootsim v0.1.87 | (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;
|
|
@@ -663,11 +663,22 @@ var APPS = [
|
|
|
663
663
|
// be holding pglite locks on ~/takeout/.orez (soot can attach takeout as
|
|
664
664
|
// a project and spin up its own orez against the same data dir).
|
|
665
665
|
readyTimeoutMs: 24e4,
|
|
666
|
+
managedPorts: (p) => {
|
|
667
|
+
const offset = p - 8081;
|
|
668
|
+
return [5433 + offset, 4848 + offset, 9200 + offset];
|
|
669
|
+
},
|
|
666
670
|
command: (p) => ({
|
|
667
|
-
cmd: "bun lite",
|
|
671
|
+
cmd: "bun lite:demo",
|
|
668
672
|
env: {
|
|
673
|
+
TAKEOUT_ENV_MODE: "development",
|
|
669
674
|
PORT_OFFSET: String(p - 8081),
|
|
670
|
-
OREZ_DATA_DIR: `${HOME}/.cache/sootsim-demo/takeout-orez
|
|
675
|
+
OREZ_DATA_DIR: `${HOME}/.cache/sootsim-demo/takeout-orez`,
|
|
676
|
+
VITE_DEMO_MODE: "1",
|
|
677
|
+
ZERO_APP_ID: "takeout",
|
|
678
|
+
ZERO_APP_PUBLICATIONS: "zero_takeout",
|
|
679
|
+
ZERO_CVR_MAX_CONNS: "4",
|
|
680
|
+
ZERO_NUM_SYNC_WORKERS: "2",
|
|
681
|
+
ZERO_UPSTREAM_MAX_CONNS: "8"
|
|
671
682
|
}
|
|
672
683
|
})
|
|
673
684
|
},
|