api-ape 2.3.0 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -3
- package/client/connectSocket.js +2 -4
- package/dist/ape.js +1 -1
- package/dist/ape.js.map +3 -3
- package/dist/api-ape.min.js +1 -1
- package/dist/api-ape.min.js.map +3 -3
- package/index.d.ts +46 -2
- package/index.js +15 -0
- package/package.json +1 -1
- package/server/README.md +30 -4
- package/server/client.js +308 -0
- package/server/index.js +26 -3
package/README.md
CHANGED
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
[](https://www.npmjs.com/package/api-ape)
|
|
4
4
|
[](https://github.com/codemeasandwich/api-ape/issues)
|
|
5
5
|
[](#zero-dependencies)
|
|
6
|
+
[](https://github.com/codemeasandwich/api-ape/security/dependabot)
|
|
6
7
|
[](#csrf-protection)
|
|
7
8
|
[](https://bundlephobia.com/package/api-ape)
|
|
8
9
|
[](#jjs-encoding)
|
|
@@ -32,7 +33,7 @@ yarn add api-ape
|
|
|
32
33
|
|
|
33
34
|
```js
|
|
34
35
|
const { createServer } = require('http')
|
|
35
|
-
const ape = require('api-ape')
|
|
36
|
+
const { ape } = require('api-ape')
|
|
36
37
|
|
|
37
38
|
const server = createServer()
|
|
38
39
|
|
|
@@ -45,7 +46,7 @@ server.listen(3000)
|
|
|
45
46
|
**With Express:**
|
|
46
47
|
```js
|
|
47
48
|
const express = require('express')
|
|
48
|
-
const ape = require('api-ape')
|
|
49
|
+
const { ape } = require('api-ape')
|
|
49
50
|
|
|
50
51
|
const app = express()
|
|
51
52
|
const server = app.listen(3000) // Get the HTTP server
|
|
@@ -344,7 +345,7 @@ module.exports = function(announcement) {
|
|
|
344
345
|
### Using ape.clients
|
|
345
346
|
|
|
346
347
|
```js
|
|
347
|
-
const ape = require('api-ape')
|
|
348
|
+
const { ape } = require('api-ape')
|
|
348
349
|
|
|
349
350
|
// Get online count
|
|
350
351
|
console.log('Online:', ape.clients.size)
|
package/client/connectSocket.js
CHANGED
|
@@ -53,12 +53,10 @@ function isDevMode() {
|
|
|
53
53
|
*/
|
|
54
54
|
function getPingUrl() {
|
|
55
55
|
const hostname = window.location.hostname
|
|
56
|
-
const localServers = ['localhost', '127.0.0.1', '[::1]']
|
|
57
|
-
const isLocal = localServers.includes(hostname)
|
|
58
56
|
const isHttps = window.location.protocol === 'https:'
|
|
59
|
-
const port =
|
|
57
|
+
const port = window.location.port || (isHttps ? 443 : 80)
|
|
60
58
|
const protocol = isHttps ? 'https' : 'http'
|
|
61
|
-
const portSuffix = (
|
|
59
|
+
const portSuffix = (port !== 80 && port !== 443) ? `:${port}` : ''
|
|
62
60
|
return `${protocol}://${hostname}${portSuffix}/api/ape/ping`
|
|
63
61
|
}
|
|
64
62
|
|
package/dist/ape.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(()=>{var $e=Object.create;var ne=Object.defineProperty;var Se=Object.getOwnPropertyDescriptor;var ke=Object.getOwnPropertyNames;var Te=Object.getPrototypeOf,Ae=Object.prototype.hasOwnProperty;var oe=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var be=(e,t,n,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of ke(t))!Ae.call(e,r)&&r!==n&&ne(e,r,{get:()=>t[r],enumerable:!(o=Se(t,r))||o.enumerable});return e};var K=(e,t,n)=>(n=e!=null?$e(Te(e)):{},be(t||!e||!e.__esModule?ne(n,"default",{value:e,enumerable:!0}):n,e));var ce=oe((ve,ie)=>{var re="0123456789ABCDEFGHJKMNPQRSTVWXYZ";function se(e){let t=Math.floor(e/32),n=e%32;return t===0?re[n]:se(t)+re[n]}function Ee(e){for(var t=0,n=0;n<e.length;++n)t+=e.charCodeAt(n),t+=t<<10,t^=t>>6;return t+=t<<3,t^=t>>11,(t+(t<<15)&4294967295)>>>0}function Oe(e){return se(Ee(e))}ie.exports=Oe});var V=oe((et,fe)=>{function ae(e){let t={"[object RegExp]":"R","[object Date]":"D","[object Error]":"E","[object Undefined]":"U","[object Map]":"M","[object Set]":"S"},n=new WeakMap;function o(s,a=""){let p=typeof s,f=t[Object.prototype.toString.call(s)];if(f!==void 0)return f==="D"?[f,s.valueOf()]:f==="E"?[f,[s.name,s.message,s.stack]]:f==="R"?[f,s.toString()]:f==="U"?[f,null]:f==="S"?[f,Array.from(s)]:f==="M"?[f,Object.fromEntries(s)]:[f,JSON.stringify(s)];if(p==="object"&&s!==null){if(i.has(s))return["P",i.get(s)];i.set(s,a);let d=Array.isArray(s),u=d?Array.from(Array(s.length).keys()):Object.keys(s),g=d?[]:{},w=[];for(let h=0;h<u.length;h++){let m=u[h],[y,k]=o(s[m],m);d?(w.push(y),g.push(k)):s[m]!==void 0&&(g[m+(y?`<!${y}>`:"")]=k)}return n.delete(s),d&&w.find(h=>!!h)?[`[${w.join()}]`,g]:["",g]}else return["",s]}let r=[];Array.isArray(e)?r=Array.from(Array(e.length).keys()):r=Object.keys(e);let i=new WeakMap;i.set(e,[]);function l(s,a=[]){let p=typeof s,f=t[Object.prototype.toString.call(s)];if(f!==void 0)return f==="D"?[f,s.valueOf()]:f==="E"?[f,[s.name,s.message,s.stack]]:f==="R"?[f,s.toString()]:f==="U"?[f,null]:f==="S"?[f,Array.from(s)]:f==="M"?[f,Object.fromEntries(s)]:[f,JSON.stringify(s)];if(p==="object"&&s!==null){if(i.has(s))return["P",i.get(s)];i.set(s,a);let d=Array.isArray(s),u=d?Array.from(Array(s.length).keys()):Object.keys(s),g=d?[]:{},w=[];for(let h=0;h<u.length;h++){let m=u[h],[y,k]=l(s[m],[...a,m]);d?(w.push(y),g.push(k)):s[m]!==void 0&&(g[m+(y?`<!${y}>`:"")]=k)}return d&&w.find(h=>!!h)?[`[${w.join()}]`,g]:["",g]}else return["",s]}let c={};for(let s=0;s<r.length;s++){let a=r[s];if(e[a]!==void 0){let[p,f]=l(e[a],[a]);c[a+(p?`<!${p}>`:"")]=f}}return c}function Ce(e){return JSON.stringify(ae(e))}function De(e){return le(JSON.parse(e))}function le(e){let t={},n=[],o={R:c=>new RegExp(c),D:c=>new Date(c),P:function(c,s){return n.push([c,s]),null},E:([c,s,a])=>{let p;try{if(p=new global[c](s),p instanceof Error)p.stack=a;else throw{}}catch{p=new Error(s),p.name=c,p.stack=a}return p},U:()=>{},S:c=>new Set(c),M:c=>new Map(Object.entries(c))},r=new Map;function i(c,s,a){let p=Array.isArray(this)?this:[];if(s in o)return o[s](a,p);if(Array.isArray(a))if(s&&s.startsWith("[")){let f=s.slice(1,-1).split(","),d=[];for(let u=0;u<a.length;u++){let g=[...p,u],w=i.call(g,u.toString(),f[u],a[u]);d.push(w)}return d}else{let f=[];for(let d=0;d<a.length;d++){let u=i.call([...p,d],"","",a[d]);f.push(u)}return f}else if(typeof a=="object"&&a!==null){if(r.has(a))return r.get(a);r.set(a,{});let f={};for(let d in a){let[u,g]=l(d),w=i.call([...p,u],u,g,a[d]);f[u]=w}return r.set(a,f),f}else return a}function l(c){let s=c.match(/(.+)(<!(.)>)/);if(s)return[s[1],s[3]];let a=c.match(/(.+)(<!!(.+)>)/);if(a)return[a[1],a[3]];let p=c.match(/(.+)(<!\[(.*)>)/);return p?[p[1],"["+p[3]]:[c,void 0]}for(let c in e){let[s,a]=l(c);t[s]=i.call([s],s,a,e[c])}return n.forEach(Pe.bind(null,t)),t}function Pe(e,[t,n]){let o=t||[],r=n||[],i=e;for(let c=0;c<o.length;c++)i=i[o[c]];let l=e;for(let c=0;c<r.length-1;c++)l=l[r[c]];return l[r[r.length-1]]=i,e}fe.exports={parse:De,stringify:Ce,encode:ae,decode:le}});var pe=K(ce()),Z=K(V());var R=K(V());function ue(){let e=window.location.hostname,n=["localhost","127.0.0.1","[::1]"].includes(e),o=window.location.protocol==="https:",r=n?9010:window.location.port||(o?443:80),i=o?"https":"http",l=n||r!==80&&r!==443?`:${r}`:"";return`${i}://${e}${l}/api/ape/poll`}function _e(e){let t=[],n=-1,o=0,r=!1,i=!1;for(let c=0;c<e.length;c++){let s=e[c];if(i){i=!1;continue}if(s==="\\"&&r){i=!0;continue}if(s==='"'){r=!r;continue}if(!r){if(s==="{")o===0&&(n=c),o++;else if(s==="}"&&(o--,o===0&&n!==-1)){let a=e.slice(n,c+1);try{t.push(R.default.parse(a))}catch(p){console.error("\u{1F98D} Failed to parse stream message:",p)}n=-1}}}let l=n!==-1?e.slice(n):"";return{messages:t,remaining:l}}function de(){let e=!1,t=null,n="",o=null,r=()=>{},i=()=>{},l=()=>{},c=()=>{};async function s(){if(!e){e=!0,t=new AbortController;try{let d=await fetch(ue(),{method:"GET",credentials:"include",signal:t.signal,headers:{Accept:"application/json"}});if(!d.ok)throw new Error(`Stream connect failed: ${d.status}`);i();let u=d.body.getReader(),g=new TextDecoder;async function w(){for(;e;)try{let{done:h,value:m}=await u.read();if(h){a();return}n+=g.decode(m,{stream:!0});let{messages:y,remaining:k}=_e(n);n=k;for(let te of y)te.type!=="__heartbeat__"&&r(te)}catch(h){if(h.name==="AbortError")return;console.error("\u{1F98D} Stream read error:",h),a();return}}w()}catch(d){if(d.name==="AbortError")return;console.error("\u{1F98D} Stream connection error:",d),c(d),a()}}}function a(){e&&(o&&clearTimeout(o),o=setTimeout(()=>{e&&s()},500))}async function p(d,u,g){let w={type:d,data:u,createdAt:new Date(g)},h=await fetch(ue(),{method:"POST",credentials:"include",headers:{"Content-Type":"application/json"},body:R.default.stringify(w)});if(!h.ok){let y=await h.json().catch(()=>({error:"Unknown error"}));throw new Error(y.error||`Request failed: ${h.status}`)}return R.default.parse(await h.text()).data}function f(){e=!1,o&&(clearTimeout(o),o=null),t&&(t.abort(),t=null),n="",l()}return{connect:s,send:p,close:f,isConnected:()=>e,set onMessage(d){r=d},set onOpen(d){i=d},set onClose(d){l=d},set onError(d){c=d}}}var he,$={Offline:"offline",Walled:"walled",Disconnected:"disconnected",Connecting:"connecting",Connected:"connected",Closing:"closing"},W=typeof navigator<"u"&&!navigator.onLine?$.Offline:$.Disconnected,M=[];function T(e){W!==e&&(W=e,M.forEach(t=>t(e)))}var F="auto",A=null,S=null,b=null,I=null,Re=4e3,ge=3e4,Le=3e3,Be=6e4;function L(){return typeof window>"u"?!1:["localhost","127.0.0.1","[::1]"].includes(window.location.hostname)}function Me(){let e=window.location.hostname,n=["localhost","127.0.0.1","[::1]"].includes(e),o=window.location.protocol==="https:",r=n?9010:window.location.port||(o?443:80),i=o?"https":"http",l=n||r!==80&&r!==443?`:${r}`:"";return`${i}://${e}${l}/api/ape/ping`}async function We(){try{let e=new AbortController,t=setTimeout(()=>e.abort(),Le),n=await fetch(Me(),{cache:"no-store",signal:e.signal});if(clearTimeout(t),!n.ok)return L()&&console.error("\u{1F98D} [DEV] Ping failed: HTTP",n.status),"walled";let o=await n.json();if(o?.ok!==!0)return L()&&console.error("\u{1F98D} [DEV] Ping failed: invalid response",o),"walled";if(typeof o.ts=="number"){let r=Date.now(),i=Math.abs(r-o.ts);if(i>Be)return L()&&console.error("\u{1F98D} [DEV] Ping failed: timestamp too old/stale (skew:",i,"ms)"),"walled"}return"ok"}catch(e){return L()&&console.error("\u{1F98D} [DEV] Ping failed:",e.message||e),"walled"}}function Fe(){typeof window>"u"||(window.addEventListener("online",()=>{console.log("\u{1F98D} Browser went online, checking network..."),v()}),window.addEventListener("offline",()=>{console.log("\u{1F98D} Browser went offline"),T($.Offline)}))}typeof window<"u"&&Fe();function Ue(){let e=window.location.hostname,n=["localhost","127.0.0.1","[::1]"].includes(e),o=window.location.protocol==="https:",r=n?9010:window.location.port||(o?443:80),i=o?"wss":"ws",l=n||r!==80&&r!==443?`:${r}`:"";return`${i}://${e}${l}/api/ape`}var we=!1,xe=5e3,He=1e4,Ke="/",Ve=new Set(["on","onConnectionChange","transport"]),ye={get(e,t){if(Ve.has(t))return e[t];let n=function(o,r){let i=Ke+t,l;return arguments.length===2?(i+=o,l=r):l=o,e(i,l)};return new Proxy(n,ye)}};function Ie(e){return new Proxy(e,ye)}var C=!1,O=!1,z=!1,E={},D=[],U=[],P={};function N(){console.log("\u{1F98D} Switching to HTTP streaming transport"),A="polling",S||(S=de(),S.onMessage=async e=>{let{err:t,type:n,data:o}=e,r=o;if(o&&!t)try{r=await Y(o),r=await X(r)}catch(i){console.error("\u{1F98D} Failed to hydrate streaming data:",i)}P[n]&&P[n].forEach(i=>i({err:t,type:n,data:r})),U.forEach(i=>i({err:t,type:n,data:r}))},S.onOpen=()=>{O=!0,T($.Connected),console.log("\u{1F98D} HTTP streaming connected"),D.forEach(({type:e,data:t,resolve:n,reject:o,waiting:r,createdAt:i,timer:l})=>{clearTimeout(l);let c=Ne(e,t,i);r&&c.then(n).catch(o)}),D=[],je()},S.onClose=()=>{O=!1,T($.Disconnected)},S.onError=e=>{console.error("\u{1F98D} Streaming error:",e)}),S.connect()}function Ne(e,t,n){return S.send(e,t,n)}function je(){b||A==="polling"&&F!=="polling"&&(b=setInterval(()=>{if(A!=="polling"){clearInterval(b),b=null;return}console.log("\u{1F98D} Attempting WebSocket reconnection..."),me(!0)},ge))}function me(e=!1){let t=new WebSocket(Ue()),n=null;!e&&F==="auto"&&(n=setTimeout(()=>{t.readyState!==WebSocket.OPEN&&(console.log("\u{1F98D} WebSocket timeout, falling back to HTTP streaming"),t.close(),N())},Re)),t.onopen=()=>{n&&clearTimeout(n),e&&A==="polling"&&(console.log("\u{1F98D} WebSocket reconnected, switching from HTTP streaming"),S&&S.close(),b&&(clearInterval(b),b=null)),A="websocket",C=t,O=!0,T($.Connected),D.forEach(({type:o,data:r,resolve:i,reject:l,waiting:c,createdAt:s,timer:a})=>{clearTimeout(a);let p=z(o,r,s);c&&p.then(i).catch(l)}),D=[]},t.onmessage=async function(o){let{err:r,type:i,queryId:l,data:c}=Z.default.parse(o.data);if(l){if(E[l]){if(c&&!r)try{let a=await Y(c);a=await X(a),E[l](r,a)}catch(a){E[l](a,null)}else E[l](r,c);delete E[l]}else console.error(`\u{1F98D} No matching queryId: ${l}`);return}let s=c;if(c&&!r)try{s=await Y(c),s=await X(s)}catch(a){console.error("\u{1F98D} Failed to hydrate broadcast data:",a)}P[i]&&P[i].forEach(a=>a({err:r,type:i,data:s})),U.forEach(a=>a({err:r,type:i,data:s}))},t.onerror=function(o){n&&clearTimeout(n),console.error("socket ERROR:",o),!e&&F==="auto"&&!O&&N()},t.onclose=function(o){n&&clearTimeout(n),console.warn("socket disconnect:",o),C=!1,O=!1,A==="websocket"&&(T($.Disconnected),setTimeout(()=>we&&_(),500))}}function j(e,t=""){let n=[];if(e==null||typeof e!="object")return n;if(Array.isArray(e)){for(let o=0;o<e.length;o++)n.push(...j(e[o],t?`${t}.${o}`:String(o)));return n}for(let o of Object.keys(e))if(o.endsWith("<!L>")){let r=o.slice(0,-4),i=e[o];n.push({path:t?`${t}.${r}`:r,hash:i,originalKey:o})}else n.push(...j(e[o],t?`${t}.${o}`:o));return n}function q(e,t=""){let n=[];if(e==null||typeof e!="object")return n;if(Array.isArray(e)){for(let o=0;o<e.length;o++)n.push(...q(e[o],t?`${t}.${o}`:String(o)));return n}for(let o of Object.keys(e))if(o.endsWith("<!F>")){let r=o.slice(0,-4),i=e[o];n.push({path:t?`${t}.${r}`:r,hash:i,originalKey:o})}else n.push(...q(e[o],t?`${t}.${o}`:o));return n}function J(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(J);let t={};for(let n of Object.keys(e))if(n.endsWith("<!F>")){let o=n.slice(0,-4);t[o]=e[n]}else t[n]=J(e[n]);return t}async function X(e,t=5){let n=q(e);if(n.length===0)return e;console.log(`\u{1F98D} Fetching ${n.length} shared file(s)`);let o=J(e),r=window.location.hostname,i=["localhost","127.0.0.1","[::1]"].includes(r),l=window.location.protocol==="https:",c=i?9010:window.location.port||(l?443:80),s=l?"https":"http",a=i||c!==80&&c!==443?`:${c}`:"",p=`${s}://${r}${a}`;return await Promise.all(n.map(async({path:f,hash:d})=>{let u=0,g=100;for(;u<t;)try{let w=await fetch(`${p}/api/ape/data/${d}`,{credentials:"include"});if(!w.ok){if(w.status===404&&u<t-1){u++,await new Promise(y=>setTimeout(y,g)),g*=2;continue}throw new Error(`Failed to fetch shared file: ${w.status}`)}let h=await w.arrayBuffer();x(o,f,h),w.headers.get("X-Ape-Complete")==="1"||console.log(`\u{1F98D} Shared file ${d} still uploading (${w.headers.get("X-Ape-Total-Received")||"?"} bytes)`);break}catch(w){u>=t-1&&(console.error(`\u{1F98D} Failed to fetch shared file at ${f}:`,w),x(o,f,null)),u++,await new Promise(h=>setTimeout(h,g)),g*=2}})),o}function x(e,t,n){let o=t.split("."),r=e;for(let i=0;i<o.length-1;i++)r=r[o[i]];r[o[o.length-1]]=n}function G(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(G);let t={};for(let n of Object.keys(e))if(n.endsWith("<!L>")){let o=n.slice(0,-4);t[o]=e[n]}else t[n]=G(e[n]);return t}async function Y(e,t){let n=j(e);if(n.length===0)return e;console.log(`\u{1F98D} Fetching ${n.length} binary resource(s)`);let o=G(e),r=window.location.hostname,i=["localhost","127.0.0.1","[::1]"].includes(r),l=window.location.protocol==="https:",c=i?9010:window.location.port||(l?443:80),s=l?"https":"http",a=i||c!==80&&c!==443?`:${c}`:"",p=`${s}://${r}${a}`;return await Promise.all(n.map(async({path:f,hash:d})=>{try{let u=await fetch(`${p}/api/ape/data/${d}`,{credentials:"include",headers:{"X-Ape-Client-Id":t||""}});if(!u.ok)throw new Error(`Failed to fetch binary resource: ${u.status}`);let g=await u.arrayBuffer();x(o,f,g)}catch(u){console.error(`\u{1F98D} Failed to fetch binary resource at ${f}:`,u),x(o,f,null)}})),o}async function v(){if(typeof navigator<"u"&&!navigator.onLine){T($.Offline);return}if(T($.Connecting),await We()==="walled"){T($.Walled),qe();return}Je()}function qe(){I||(I=setTimeout(()=>{I=null,v()},ge))}function Je(){F==="polling"?N():me(!1)}function _(){return C&&C.readyState!==WebSocket.CLOSED||A==="polling"&&S?.isConnected()||W===$.Connecting||v(),B()}function Xe(e){return e==null?!1:e instanceof ArrayBuffer||ArrayBuffer.isView(e)||typeof Blob<"u"&&e instanceof Blob}function Ge(e){return typeof Blob<"u"&&e instanceof Blob?"B":"A"}function Ye(e){let t=0;for(let n=0;n<e.length;n++){let o=e.charCodeAt(n);t=(t<<5)-t+o,t=t&t}return Math.abs(t).toString(36)}function Q(e,t=""){if(e==null)return{processedData:e,uploads:[]};if(Xe(e)){let n=Ge(e),o=Ye(t||"root");return{processedData:{__ape_upload__:o},uploads:[{path:t,hash:o,data:e,tag:n}]}}if(Array.isArray(e)){let n=[],o=[];for(let r=0;r<e.length;r++){let i=t?`${t}.${r}`:String(r),{processedData:l,uploads:c}=Q(e[r],i);n.push(l),o.push(...c)}return{processedData:n,uploads:o}}if(typeof e=="object"){let n={},o=[];for(let r of Object.keys(e)){let i=t?`${t}.${r}`:r,{processedData:l,uploads:c}=Q(e[r],i);if(c.length>0&&l?.__ape_upload__){let s=c[c.length-1].tag;n[`${r}<!${s}>`]=l.__ape_upload__}else n[r]=l;o.push(...c)}return{processedData:n,uploads:o}}return{processedData:e,uploads:[]}}async function Qe(e,t){if(t.length===0)return;let n=window.location.hostname,o=["localhost","127.0.0.1","[::1]"].includes(n),r=window.location.protocol==="https:",i=o?9010:window.location.port||(r?443:80),l=r?"https":"http",c=o||i!==80&&i!==443?`:${i}`:"",s=`${l}://${n}${c}`;console.log(`\u{1F98D} Uploading ${t.length} binary file(s)`),await Promise.all(t.map(async({hash:a,data:p})=>{try{let f=await fetch(`${s}/api/ape/data/${e}/${a}`,{method:"PUT",credentials:"include",headers:{"Content-Type":"application/octet-stream"},body:p});if(!f.ok)throw new Error(`Upload failed: ${f.status}`)}catch(f){throw console.error(`\u{1F98D} Failed to upload binary at ${a}:`,f),f}}))}z=function(e,t,n,o){let r,i=!1,l=n+He-Date.now(),c=setTimeout(()=>{i&&r(new Error("Request Timedout for :"+e))},l),{processedData:s,uploads:a}=Q(t),p={type:e,data:s,createdAt:new Date(n),requestedAt:o?void 0:new Date},f=Z.default.stringify(p),d=(0,pe.default)(f),u=new Promise((h,m)=>{r=m,E[d]=(y,k)=>{clearTimeout(c),u.then=g.bind(u),y?m(y):h(k)},C.send(f),a.length>0&&Qe(d,a).catch(y=>{console.error("\u{1F98D} Binary upload failed:",y)})}),g=u.then;u.then=h=>(i=!0,u.then=g.bind(u),u.catch=w.bind(u),g.call(u,h));let w=u.catch;return u.catch=h=>(i=!0,u.catch=w.bind(u),u.then=g.bind(u),w.call(u,h)),u};var Ze=(e,t)=>{if(typeof e!="string")throw new Error("Missing Path vaule");let n=Date.now();if(O)return z(e,t,n,!0);let o=n+xe-Date.now(),r=setTimeout(()=>{let a="Request not sent for :"+e;if(i.waiting)i.reject(new Error(a));else throw new Error(a)},o),i={type:e,data:t,resolve:void 0,reject:void 0,waiting:!1,createdAt:n,timer:r},l=new Promise((a,p)=>{i.resolve=a,i.reject=p}),c=l.then,s=l.catch;return l.then=a=>(i.waiting=!0,l.then=c.bind(l),l.catch=s.bind(l),c.call(l,a)),l.catch=a=>(i.waiting=!0,l.catch=s.bind(l),l.then=c.bind(l),s.call(l,a)),D.push(i),C||_(),l};function B(){return{sender:Ie(Ze),setOnReceiver:(e,t)=>{typeof e=="string"?P[e]=[t]:U.includes(e)||U.push(e)},onConnectionChange:e=>(M.push(e),e(W),()=>{let t=M.indexOf(e);t>-1&&M.splice(t,1)}),get transport(){return A}}}_.autoReconnect=()=>we=!0;_.ConnectionState=$;he=_;var ee=he;var H=ee();ee.autoReconnect();window.api=H.sender;Object.defineProperty(window.api,"on",{value:H.setOnReceiver,writable:!1,enumerable:!1,configurable:!1});Object.defineProperty(window.api,"onConnectionChange",{value:H.onConnectionChange,writable:!1,enumerable:!1,configurable:!1});Object.defineProperty(window.api,"transport",{get:()=>H.transport,enumerable:!1,configurable:!1});})();
|
|
1
|
+
(()=>{var $e=Object.create;var ne=Object.defineProperty;var Se=Object.getOwnPropertyDescriptor;var ke=Object.getOwnPropertyNames;var Te=Object.getPrototypeOf,Ae=Object.prototype.hasOwnProperty;var oe=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var be=(e,t,n,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of ke(t))!Ae.call(e,r)&&r!==n&&ne(e,r,{get:()=>t[r],enumerable:!(o=Se(t,r))||o.enumerable});return e};var K=(e,t,n)=>(n=e!=null?$e(Te(e)):{},be(t||!e||!e.__esModule?ne(n,"default",{value:e,enumerable:!0}):n,e));var ce=oe((ve,ie)=>{var re="0123456789ABCDEFGHJKMNPQRSTVWXYZ";function se(e){let t=Math.floor(e/32),n=e%32;return t===0?re[n]:se(t)+re[n]}function Ee(e){for(var t=0,n=0;n<e.length;++n)t+=e.charCodeAt(n),t+=t<<10,t^=t>>6;return t+=t<<3,t^=t>>11,(t+(t<<15)&4294967295)>>>0}function Oe(e){return se(Ee(e))}ie.exports=Oe});var V=oe((et,fe)=>{function ae(e){let t={"[object RegExp]":"R","[object Date]":"D","[object Error]":"E","[object Undefined]":"U","[object Map]":"M","[object Set]":"S"},n=new WeakMap;function o(s,a=""){let p=typeof s,f=t[Object.prototype.toString.call(s)];if(f!==void 0)return f==="D"?[f,s.valueOf()]:f==="E"?[f,[s.name,s.message,s.stack]]:f==="R"?[f,s.toString()]:f==="U"?[f,null]:f==="S"?[f,Array.from(s)]:f==="M"?[f,Object.fromEntries(s)]:[f,JSON.stringify(s)];if(p==="object"&&s!==null){if(i.has(s))return["P",i.get(s)];i.set(s,a);let d=Array.isArray(s),u=d?Array.from(Array(s.length).keys()):Object.keys(s),g=d?[]:{},w=[];for(let h=0;h<u.length;h++){let m=u[h],[y,k]=o(s[m],m);d?(w.push(y),g.push(k)):s[m]!==void 0&&(g[m+(y?`<!${y}>`:"")]=k)}return n.delete(s),d&&w.find(h=>!!h)?[`[${w.join()}]`,g]:["",g]}else return["",s]}let r=[];Array.isArray(e)?r=Array.from(Array(e.length).keys()):r=Object.keys(e);let i=new WeakMap;i.set(e,[]);function l(s,a=[]){let p=typeof s,f=t[Object.prototype.toString.call(s)];if(f!==void 0)return f==="D"?[f,s.valueOf()]:f==="E"?[f,[s.name,s.message,s.stack]]:f==="R"?[f,s.toString()]:f==="U"?[f,null]:f==="S"?[f,Array.from(s)]:f==="M"?[f,Object.fromEntries(s)]:[f,JSON.stringify(s)];if(p==="object"&&s!==null){if(i.has(s))return["P",i.get(s)];i.set(s,a);let d=Array.isArray(s),u=d?Array.from(Array(s.length).keys()):Object.keys(s),g=d?[]:{},w=[];for(let h=0;h<u.length;h++){let m=u[h],[y,k]=l(s[m],[...a,m]);d?(w.push(y),g.push(k)):s[m]!==void 0&&(g[m+(y?`<!${y}>`:"")]=k)}return d&&w.find(h=>!!h)?[`[${w.join()}]`,g]:["",g]}else return["",s]}let c={};for(let s=0;s<r.length;s++){let a=r[s];if(e[a]!==void 0){let[p,f]=l(e[a],[a]);c[a+(p?`<!${p}>`:"")]=f}}return c}function Ce(e){return JSON.stringify(ae(e))}function De(e){return le(JSON.parse(e))}function le(e){let t={},n=[],o={R:c=>new RegExp(c),D:c=>new Date(c),P:function(c,s){return n.push([c,s]),null},E:([c,s,a])=>{let p;try{if(p=new global[c](s),p instanceof Error)p.stack=a;else throw{}}catch{p=new Error(s),p.name=c,p.stack=a}return p},U:()=>{},S:c=>new Set(c),M:c=>new Map(Object.entries(c))},r=new Map;function i(c,s,a){let p=Array.isArray(this)?this:[];if(s in o)return o[s](a,p);if(Array.isArray(a))if(s&&s.startsWith("[")){let f=s.slice(1,-1).split(","),d=[];for(let u=0;u<a.length;u++){let g=[...p,u],w=i.call(g,u.toString(),f[u],a[u]);d.push(w)}return d}else{let f=[];for(let d=0;d<a.length;d++){let u=i.call([...p,d],"","",a[d]);f.push(u)}return f}else if(typeof a=="object"&&a!==null){if(r.has(a))return r.get(a);r.set(a,{});let f={};for(let d in a){let[u,g]=l(d),w=i.call([...p,u],u,g,a[d]);f[u]=w}return r.set(a,f),f}else return a}function l(c){let s=c.match(/(.+)(<!(.)>)/);if(s)return[s[1],s[3]];let a=c.match(/(.+)(<!!(.+)>)/);if(a)return[a[1],a[3]];let p=c.match(/(.+)(<!\[(.*)>)/);return p?[p[1],"["+p[3]]:[c,void 0]}for(let c in e){let[s,a]=l(c);t[s]=i.call([s],s,a,e[c])}return n.forEach(Pe.bind(null,t)),t}function Pe(e,[t,n]){let o=t||[],r=n||[],i=e;for(let c=0;c<o.length;c++)i=i[o[c]];let l=e;for(let c=0;c<r.length-1;c++)l=l[r[c]];return l[r[r.length-1]]=i,e}fe.exports={parse:De,stringify:Ce,encode:ae,decode:le}});var pe=K(ce()),Z=K(V());var R=K(V());function ue(){let e=window.location.hostname,n=["localhost","127.0.0.1","[::1]"].includes(e),o=window.location.protocol==="https:",r=n?9010:window.location.port||(o?443:80),i=o?"https":"http",l=n||r!==80&&r!==443?`:${r}`:"";return`${i}://${e}${l}/api/ape/poll`}function _e(e){let t=[],n=-1,o=0,r=!1,i=!1;for(let c=0;c<e.length;c++){let s=e[c];if(i){i=!1;continue}if(s==="\\"&&r){i=!0;continue}if(s==='"'){r=!r;continue}if(!r){if(s==="{")o===0&&(n=c),o++;else if(s==="}"&&(o--,o===0&&n!==-1)){let a=e.slice(n,c+1);try{t.push(R.default.parse(a))}catch(p){console.error("\u{1F98D} Failed to parse stream message:",p)}n=-1}}}let l=n!==-1?e.slice(n):"";return{messages:t,remaining:l}}function de(){let e=!1,t=null,n="",o=null,r=()=>{},i=()=>{},l=()=>{},c=()=>{};async function s(){if(!e){e=!0,t=new AbortController;try{let d=await fetch(ue(),{method:"GET",credentials:"include",signal:t.signal,headers:{Accept:"application/json"}});if(!d.ok)throw new Error(`Stream connect failed: ${d.status}`);i();let u=d.body.getReader(),g=new TextDecoder;async function w(){for(;e;)try{let{done:h,value:m}=await u.read();if(h){a();return}n+=g.decode(m,{stream:!0});let{messages:y,remaining:k}=_e(n);n=k;for(let te of y)te.type!=="__heartbeat__"&&r(te)}catch(h){if(h.name==="AbortError")return;console.error("\u{1F98D} Stream read error:",h),a();return}}w()}catch(d){if(d.name==="AbortError")return;console.error("\u{1F98D} Stream connection error:",d),c(d),a()}}}function a(){e&&(o&&clearTimeout(o),o=setTimeout(()=>{e&&s()},500))}async function p(d,u,g){let w={type:d,data:u,createdAt:new Date(g)},h=await fetch(ue(),{method:"POST",credentials:"include",headers:{"Content-Type":"application/json"},body:R.default.stringify(w)});if(!h.ok){let y=await h.json().catch(()=>({error:"Unknown error"}));throw new Error(y.error||`Request failed: ${h.status}`)}return R.default.parse(await h.text()).data}function f(){e=!1,o&&(clearTimeout(o),o=null),t&&(t.abort(),t=null),n="",l()}return{connect:s,send:p,close:f,isConnected:()=>e,set onMessage(d){r=d},set onOpen(d){i=d},set onClose(d){l=d},set onError(d){c=d}}}var he,$={Offline:"offline",Walled:"walled",Disconnected:"disconnected",Connecting:"connecting",Connected:"connected",Closing:"closing"},W=typeof navigator<"u"&&!navigator.onLine?$.Offline:$.Disconnected,M=[];function T(e){W!==e&&(W=e,M.forEach(t=>t(e)))}var F="auto",A=null,S=null,b=null,I=null,Re=4e3,ge=3e4,Le=3e3,Be=6e4;function L(){return typeof window>"u"?!1:["localhost","127.0.0.1","[::1]"].includes(window.location.hostname)}function Me(){let e=window.location.hostname,t=window.location.protocol==="https:",n=window.location.port||(t?443:80),o=t?"https":"http",r=n!==80&&n!==443?`:${n}`:"";return`${o}://${e}${r}/api/ape/ping`}async function We(){try{let e=new AbortController,t=setTimeout(()=>e.abort(),Le),n=await fetch(Me(),{cache:"no-store",signal:e.signal});if(clearTimeout(t),!n.ok)return L()&&console.error("\u{1F98D} [DEV] Ping failed: HTTP",n.status),"walled";let o=await n.json();if(o?.ok!==!0)return L()&&console.error("\u{1F98D} [DEV] Ping failed: invalid response",o),"walled";if(typeof o.ts=="number"){let r=Date.now(),i=Math.abs(r-o.ts);if(i>Be)return L()&&console.error("\u{1F98D} [DEV] Ping failed: timestamp too old/stale (skew:",i,"ms)"),"walled"}return"ok"}catch(e){return L()&&console.error("\u{1F98D} [DEV] Ping failed:",e.message||e),"walled"}}function Fe(){typeof window>"u"||(window.addEventListener("online",()=>{console.log("\u{1F98D} Browser went online, checking network..."),v()}),window.addEventListener("offline",()=>{console.log("\u{1F98D} Browser went offline"),T($.Offline)}))}typeof window<"u"&&Fe();function Ue(){let e=window.location.hostname,n=["localhost","127.0.0.1","[::1]"].includes(e),o=window.location.protocol==="https:",r=n?9010:window.location.port||(o?443:80),i=o?"wss":"ws",l=n||r!==80&&r!==443?`:${r}`:"";return`${i}://${e}${l}/api/ape`}var we=!1,xe=5e3,He=1e4,Ke="/",Ve=new Set(["on","onConnectionChange","transport"]),ye={get(e,t){if(Ve.has(t))return e[t];let n=function(o,r){let i=Ke+t,l;return arguments.length===2?(i+=o,l=r):l=o,e(i,l)};return new Proxy(n,ye)}};function Ie(e){return new Proxy(e,ye)}var C=!1,O=!1,z=!1,E={},D=[],U=[],P={};function N(){console.log("\u{1F98D} Switching to HTTP streaming transport"),A="polling",S||(S=de(),S.onMessage=async e=>{let{err:t,type:n,data:o}=e,r=o;if(o&&!t)try{r=await Y(o),r=await X(r)}catch(i){console.error("\u{1F98D} Failed to hydrate streaming data:",i)}P[n]&&P[n].forEach(i=>i({err:t,type:n,data:r})),U.forEach(i=>i({err:t,type:n,data:r}))},S.onOpen=()=>{O=!0,T($.Connected),console.log("\u{1F98D} HTTP streaming connected"),D.forEach(({type:e,data:t,resolve:n,reject:o,waiting:r,createdAt:i,timer:l})=>{clearTimeout(l);let c=Ne(e,t,i);r&&c.then(n).catch(o)}),D=[],je()},S.onClose=()=>{O=!1,T($.Disconnected)},S.onError=e=>{console.error("\u{1F98D} Streaming error:",e)}),S.connect()}function Ne(e,t,n){return S.send(e,t,n)}function je(){b||A==="polling"&&F!=="polling"&&(b=setInterval(()=>{if(A!=="polling"){clearInterval(b),b=null;return}console.log("\u{1F98D} Attempting WebSocket reconnection..."),me(!0)},ge))}function me(e=!1){let t=new WebSocket(Ue()),n=null;!e&&F==="auto"&&(n=setTimeout(()=>{t.readyState!==WebSocket.OPEN&&(console.log("\u{1F98D} WebSocket timeout, falling back to HTTP streaming"),t.close(),N())},Re)),t.onopen=()=>{n&&clearTimeout(n),e&&A==="polling"&&(console.log("\u{1F98D} WebSocket reconnected, switching from HTTP streaming"),S&&S.close(),b&&(clearInterval(b),b=null)),A="websocket",C=t,O=!0,T($.Connected),D.forEach(({type:o,data:r,resolve:i,reject:l,waiting:c,createdAt:s,timer:a})=>{clearTimeout(a);let p=z(o,r,s);c&&p.then(i).catch(l)}),D=[]},t.onmessage=async function(o){let{err:r,type:i,queryId:l,data:c}=Z.default.parse(o.data);if(l){if(E[l]){if(c&&!r)try{let a=await Y(c);a=await X(a),E[l](r,a)}catch(a){E[l](a,null)}else E[l](r,c);delete E[l]}else console.error(`\u{1F98D} No matching queryId: ${l}`);return}let s=c;if(c&&!r)try{s=await Y(c),s=await X(s)}catch(a){console.error("\u{1F98D} Failed to hydrate broadcast data:",a)}P[i]&&P[i].forEach(a=>a({err:r,type:i,data:s})),U.forEach(a=>a({err:r,type:i,data:s}))},t.onerror=function(o){n&&clearTimeout(n),console.error("socket ERROR:",o),!e&&F==="auto"&&!O&&N()},t.onclose=function(o){n&&clearTimeout(n),console.warn("socket disconnect:",o),C=!1,O=!1,A==="websocket"&&(T($.Disconnected),setTimeout(()=>we&&_(),500))}}function j(e,t=""){let n=[];if(e==null||typeof e!="object")return n;if(Array.isArray(e)){for(let o=0;o<e.length;o++)n.push(...j(e[o],t?`${t}.${o}`:String(o)));return n}for(let o of Object.keys(e))if(o.endsWith("<!L>")){let r=o.slice(0,-4),i=e[o];n.push({path:t?`${t}.${r}`:r,hash:i,originalKey:o})}else n.push(...j(e[o],t?`${t}.${o}`:o));return n}function q(e,t=""){let n=[];if(e==null||typeof e!="object")return n;if(Array.isArray(e)){for(let o=0;o<e.length;o++)n.push(...q(e[o],t?`${t}.${o}`:String(o)));return n}for(let o of Object.keys(e))if(o.endsWith("<!F>")){let r=o.slice(0,-4),i=e[o];n.push({path:t?`${t}.${r}`:r,hash:i,originalKey:o})}else n.push(...q(e[o],t?`${t}.${o}`:o));return n}function J(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(J);let t={};for(let n of Object.keys(e))if(n.endsWith("<!F>")){let o=n.slice(0,-4);t[o]=e[n]}else t[n]=J(e[n]);return t}async function X(e,t=5){let n=q(e);if(n.length===0)return e;console.log(`\u{1F98D} Fetching ${n.length} shared file(s)`);let o=J(e),r=window.location.hostname,i=["localhost","127.0.0.1","[::1]"].includes(r),l=window.location.protocol==="https:",c=i?9010:window.location.port||(l?443:80),s=l?"https":"http",a=i||c!==80&&c!==443?`:${c}`:"",p=`${s}://${r}${a}`;return await Promise.all(n.map(async({path:f,hash:d})=>{let u=0,g=100;for(;u<t;)try{let w=await fetch(`${p}/api/ape/data/${d}`,{credentials:"include"});if(!w.ok){if(w.status===404&&u<t-1){u++,await new Promise(y=>setTimeout(y,g)),g*=2;continue}throw new Error(`Failed to fetch shared file: ${w.status}`)}let h=await w.arrayBuffer();x(o,f,h),w.headers.get("X-Ape-Complete")==="1"||console.log(`\u{1F98D} Shared file ${d} still uploading (${w.headers.get("X-Ape-Total-Received")||"?"} bytes)`);break}catch(w){u>=t-1&&(console.error(`\u{1F98D} Failed to fetch shared file at ${f}:`,w),x(o,f,null)),u++,await new Promise(h=>setTimeout(h,g)),g*=2}})),o}function x(e,t,n){let o=t.split("."),r=e;for(let i=0;i<o.length-1;i++)r=r[o[i]];r[o[o.length-1]]=n}function G(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(G);let t={};for(let n of Object.keys(e))if(n.endsWith("<!L>")){let o=n.slice(0,-4);t[o]=e[n]}else t[n]=G(e[n]);return t}async function Y(e,t){let n=j(e);if(n.length===0)return e;console.log(`\u{1F98D} Fetching ${n.length} binary resource(s)`);let o=G(e),r=window.location.hostname,i=["localhost","127.0.0.1","[::1]"].includes(r),l=window.location.protocol==="https:",c=i?9010:window.location.port||(l?443:80),s=l?"https":"http",a=i||c!==80&&c!==443?`:${c}`:"",p=`${s}://${r}${a}`;return await Promise.all(n.map(async({path:f,hash:d})=>{try{let u=await fetch(`${p}/api/ape/data/${d}`,{credentials:"include",headers:{"X-Ape-Client-Id":t||""}});if(!u.ok)throw new Error(`Failed to fetch binary resource: ${u.status}`);let g=await u.arrayBuffer();x(o,f,g)}catch(u){console.error(`\u{1F98D} Failed to fetch binary resource at ${f}:`,u),x(o,f,null)}})),o}async function v(){if(typeof navigator<"u"&&!navigator.onLine){T($.Offline);return}if(T($.Connecting),await We()==="walled"){T($.Walled),qe();return}Je()}function qe(){I||(I=setTimeout(()=>{I=null,v()},ge))}function Je(){F==="polling"?N():me(!1)}function _(){return C&&C.readyState!==WebSocket.CLOSED||A==="polling"&&S?.isConnected()||W===$.Connecting||v(),B()}function Xe(e){return e==null?!1:e instanceof ArrayBuffer||ArrayBuffer.isView(e)||typeof Blob<"u"&&e instanceof Blob}function Ge(e){return typeof Blob<"u"&&e instanceof Blob?"B":"A"}function Ye(e){let t=0;for(let n=0;n<e.length;n++){let o=e.charCodeAt(n);t=(t<<5)-t+o,t=t&t}return Math.abs(t).toString(36)}function Q(e,t=""){if(e==null)return{processedData:e,uploads:[]};if(Xe(e)){let n=Ge(e),o=Ye(t||"root");return{processedData:{__ape_upload__:o},uploads:[{path:t,hash:o,data:e,tag:n}]}}if(Array.isArray(e)){let n=[],o=[];for(let r=0;r<e.length;r++){let i=t?`${t}.${r}`:String(r),{processedData:l,uploads:c}=Q(e[r],i);n.push(l),o.push(...c)}return{processedData:n,uploads:o}}if(typeof e=="object"){let n={},o=[];for(let r of Object.keys(e)){let i=t?`${t}.${r}`:r,{processedData:l,uploads:c}=Q(e[r],i);if(c.length>0&&l?.__ape_upload__){let s=c[c.length-1].tag;n[`${r}<!${s}>`]=l.__ape_upload__}else n[r]=l;o.push(...c)}return{processedData:n,uploads:o}}return{processedData:e,uploads:[]}}async function Qe(e,t){if(t.length===0)return;let n=window.location.hostname,o=["localhost","127.0.0.1","[::1]"].includes(n),r=window.location.protocol==="https:",i=o?9010:window.location.port||(r?443:80),l=r?"https":"http",c=o||i!==80&&i!==443?`:${i}`:"",s=`${l}://${n}${c}`;console.log(`\u{1F98D} Uploading ${t.length} binary file(s)`),await Promise.all(t.map(async({hash:a,data:p})=>{try{let f=await fetch(`${s}/api/ape/data/${e}/${a}`,{method:"PUT",credentials:"include",headers:{"Content-Type":"application/octet-stream"},body:p});if(!f.ok)throw new Error(`Upload failed: ${f.status}`)}catch(f){throw console.error(`\u{1F98D} Failed to upload binary at ${a}:`,f),f}}))}z=function(e,t,n,o){let r,i=!1,l=n+He-Date.now(),c=setTimeout(()=>{i&&r(new Error("Request Timedout for :"+e))},l),{processedData:s,uploads:a}=Q(t),p={type:e,data:s,createdAt:new Date(n),requestedAt:o?void 0:new Date},f=Z.default.stringify(p),d=(0,pe.default)(f),u=new Promise((h,m)=>{r=m,E[d]=(y,k)=>{clearTimeout(c),u.then=g.bind(u),y?m(y):h(k)},C.send(f),a.length>0&&Qe(d,a).catch(y=>{console.error("\u{1F98D} Binary upload failed:",y)})}),g=u.then;u.then=h=>(i=!0,u.then=g.bind(u),u.catch=w.bind(u),g.call(u,h));let w=u.catch;return u.catch=h=>(i=!0,u.catch=w.bind(u),u.then=g.bind(u),w.call(u,h)),u};var Ze=(e,t)=>{if(typeof e!="string")throw new Error("Missing Path vaule");let n=Date.now();if(O)return z(e,t,n,!0);let o=n+xe-Date.now(),r=setTimeout(()=>{let a="Request not sent for :"+e;if(i.waiting)i.reject(new Error(a));else throw new Error(a)},o),i={type:e,data:t,resolve:void 0,reject:void 0,waiting:!1,createdAt:n,timer:r},l=new Promise((a,p)=>{i.resolve=a,i.reject=p}),c=l.then,s=l.catch;return l.then=a=>(i.waiting=!0,l.then=c.bind(l),l.catch=s.bind(l),c.call(l,a)),l.catch=a=>(i.waiting=!0,l.catch=s.bind(l),l.then=c.bind(l),s.call(l,a)),D.push(i),C||_(),l};function B(){return{sender:Ie(Ze),setOnReceiver:(e,t)=>{typeof e=="string"?P[e]=[t]:U.includes(e)||U.push(e)},onConnectionChange:e=>(M.push(e),e(W),()=>{let t=M.indexOf(e);t>-1&&M.splice(t,1)}),get transport(){return A}}}_.autoReconnect=()=>we=!0;_.ConnectionState=$;he=_;var ee=he;var H=ee();ee.autoReconnect();window.api=H.sender;Object.defineProperty(window.api,"on",{value:H.setOnReceiver,writable:!1,enumerable:!1,configurable:!1});Object.defineProperty(window.api,"onConnectionChange",{value:H.onConnectionChange,writable:!1,enumerable:!1,configurable:!1});Object.defineProperty(window.api,"transport",{get:()=>H.transport,enumerable:!1,configurable:!1});})();
|
|
2
2
|
//# sourceMappingURL=ape.js.map
|
package/dist/ape.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../utils/messageHash.js", "../utils/jss.js", "../client/connectSocket.js", "../client/transports/streaming.js", "../client/browser.js"],
|
|
4
|
-
"sourcesContent": ["const alphabet = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\"\n/*\nfunction charValue(char){\n return alphabet.indexOf(char.toUpperCase())\n} // END charValue\n\nfunction fromBase32(b32){\n if (0 === b32.length) {\n return 0\n }\n return charValue(b32.slice(-1)) + fromBase32(b32.slice(0,-1)) * 32\n} // END fromBase32\n*/\nfunction toBase32 (n){\n const remainder = Math.floor(n/32)\n const current = n % 32\n if (0 === remainder) {\n return alphabet[current]\n }\n return toBase32(remainder)+alphabet[current]\n} // END toBase32\n\nfunction jenkinsOneAtATimeHash(keyString){\n \n var hash = 0\n \n for (var charIndex = 0; charIndex < keyString.length; ++charIndex)\n {\n hash += keyString.charCodeAt(charIndex);\n hash += hash << 10;\n hash ^= hash >> 6;\n }\n hash += hash << 3;\n hash ^= hash >> 11;\n //4,294,967,295 is FFFFFFFF, the maximum 32 bit unsigned integer value, used here as a mask.\n return (((hash + (hash << 15)) & 4294967295) >>> 0)\n} // END jenkinsOneAtATimeHash\n\nfunction messageHash(messageSt){\n return toBase32(jenkinsOneAtATimeHash(messageSt))\n} // END messageHash\n\nmodule.exports = messageHash", "//JsonSuperSet\n\n// TODO: add tests\n// check for any repeated ref not just cyclical references\n// support nasted array a<![,,[D]]>:[\"a\",\"b\",[Date]]\n// support array for the same type a<![*D]>:[Date,Date,Date]\n\nfunction encode(obj) {\n const tagLookup = {\n '[object RegExp]': 'R',\n '[object Date]': 'D',\n '[object Error]': 'E',\n \"[object Undefined]\": 'U',\n \"[object Map]\": 'M',\n \"[object Set]\": 'S',\n };\n const visited = new WeakMap();\n\n function encodeValue(value, path = '') {\n const type = typeof value;\n const tag = tagLookup[Object.prototype.toString.call(value)];\n // console.log({tag,value,path})\n if (tag !== undefined) {\n if ('D' === tag) return [tag, value.valueOf()];\n if ('E' === tag) return [tag, [value.name, value.message, value.stack]];\n if ('R' === tag) return [tag, value.toString()];\n if ('U' === tag) return [tag, null];\n if ('S' === tag) return [tag, Array.from(value)];\n if ('M' === tag) return [tag, Object.fromEntries(value)];\n\n return [tag, JSON.stringify(value)];\n } else if (type === 'object' && value !== null) {\n /*if (value.$ID) {\n return ['', value.$ID];\n }*/\n if (visitedEncode.has(value)) {\n return ['P', visitedEncode.get(value)];\n }\n visitedEncode.set(value, path);\n const isArray = Array.isArray(value);\n // keep index with undefined in Array\n const keys = isArray ? Array.from(Array(value.length).keys()) : Object.keys(value);\n const result = isArray ? [] : {};\n const typesFound = [];\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const [t, v] = encodeValue(value[key], key);\n // console.log([t, v])\n if (isArray) {\n typesFound.push(t);\n result.push(v);\n // remove key with undefined from Objects\n } else if (value[key] !== undefined) {\n result[key + (t ? `<!${t}>` : '')] = v;\n }\n }\n\n visited.delete(value);\n if (isArray && typesFound.find((t) => !!t)) {\n return [`[${typesFound.join()}]`, result];\n }\n return ['', result];\n } else {\n return ['', value];\n }\n } // END encodeValue\n\n let keys = [];\n // console.log(obj)\n if (Array.isArray(obj)) {\n keys = Array.from(Array(obj.length).keys())\n } else {\n keys = Object.keys(obj);\n }\n\n // Track root object to handle self-references\n const visitedEncode = new WeakMap();\n visitedEncode.set(obj, []); // Root path is empty array\n\n function encodeValueWithVisited(value, path = []) {\n const type = typeof value;\n const tag = tagLookup[Object.prototype.toString.call(value)];\n if (tag !== undefined) {\n if ('D' === tag) return [tag, value.valueOf()];\n if ('E' === tag) return [tag, [value.name, value.message, value.stack]];\n if ('R' === tag) return [tag, value.toString()];\n if ('U' === tag) return [tag, null];\n if ('S' === tag) return [tag, Array.from(value)];\n if ('M' === tag) return [tag, Object.fromEntries(value)];\n return [tag, JSON.stringify(value)];\n } else if (type === 'object' && value !== null) {\n if (visitedEncode.has(value)) {\n return ['P', visitedEncode.get(value)]; // Return array path\n }\n visitedEncode.set(value, path);\n const isArray = Array.isArray(value);\n const objKeys = isArray ? Array.from(Array(value.length).keys()) : Object.keys(value);\n const result = isArray ? [] : {};\n const typesFound = [];\n for (let i = 0; i < objKeys.length; i++) {\n const key = objKeys[i];\n const [t, v] = encodeValueWithVisited(value[key], [...path, key]); // Append key to path array\n if (isArray) {\n typesFound.push(t);\n result.push(v);\n } else if (value[key] !== undefined) {\n result[key + (t ? `<!${t}>` : '')] = v;\n }\n }\n if (isArray && typesFound.find((t) => !!t)) {\n return [`[${typesFound.join()}]`, result];\n }\n return ['', result];\n } else {\n return ['', value];\n }\n }\n\n const result = {};\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n // remove key with undefined from Objects\n if (obj[key] !== undefined) {\n const [t, v] = encodeValueWithVisited(obj[key], [key]); // Start path with single key\n result[key + (t ? `<!${t}>` : '')] = v;\n }\n }\n return result;\n} // END encode\n\nfunction stringify(obj) {\n return JSON.stringify(encode(obj))\n}\n\n\nfunction parse(encoded) {\n return decode(JSON.parse(encoded))\n}\n\nfunction decode(data) {\n const result = {};\n const pointers2Res = [];\n const tagLookup = {\n R: (s) => new RegExp(s),\n D: (n) => new Date(n),\n P: function (sourceToPointAt, replaceAtThisPlace) {\n // Both paths are now arrays\n pointers2Res.push([sourceToPointAt, replaceAtThisPlace]);\n return null; // Placeholder, will be replaced by changeAttributeReference\n },\n E: ([name, message, stack]) => {\n let err;\n try {\n err = new global[name](message);\n if (err instanceof Error) err.stack = stack;\n else throw {};\n } catch (e) {\n err = new Error(message);\n err.name = name;\n err.stack = stack;\n }\n return err;\n },\n U: () => undefined,\n S: (a) => new Set(a),\n M: (o) => new Map(Object.entries(o))\n };\n const visited = new Map();\n\n function decodeValue(name, tag, val) {\n // this is now an array path\n const currentPath = Array.isArray(this) ? this : [];\n\n if (tag in tagLookup) {\n return tagLookup[tag](val, currentPath);\n } else if (Array.isArray(val)) {\n if (tag && tag.startsWith('[')) {\n const typeTags = tag.slice(1, -1).split(',');\n const res = [];\n for (let i = 0; i < val.length; i++) {\n // Pass path with array index appended\n const itemPath = [...currentPath, i];\n const decodedValue = decodeValue.call(\n itemPath,\n i.toString(),\n typeTags[i],\n val[i]\n );\n res.push(decodedValue);\n }\n return res;\n } else {\n const res = [];\n for (let i = 0; i < val.length; i++) {\n const decodedValue = decodeValue.call([...currentPath, i], '', '', val[i]);\n res.push(decodedValue);\n }\n return res;\n }\n } else if ('object' === typeof val && val !== null) {\n if (visited.has(val)) {\n return visited.get(val);\n }\n visited.set(val, {});\n const res = {};\n for (const key in val) {\n const [nam, t] = parseKeyWithTags(key);\n const decodedValue = decodeValue.call(\n [...currentPath, nam],\n nam,\n t,\n val[key]\n );\n res[nam] = decodedValue;\n }\n visited.set(val, res);\n return res;\n } else {\n return val;\n }\n } // END decodeValue\n\n function parseKeyWithTags(key) {\n const match = key.match(/(.+)(<!(.)>)/);\n if (match) {\n return [match[1], match[3]];\n }\n // Try multi-character tags like array types [,D,]\n const multiMatch = key.match(/(.+)(<!!(.+)>)/);\n if (multiMatch) {\n return [multiMatch[1], multiMatch[3]];\n }\n // Also handle array type tags that start with [\n const arrayMatch = key.match(/(.+)(<!\\[(.*)>)/);\n if (arrayMatch) {\n return [arrayMatch[1], '[' + arrayMatch[3]];\n }\n return [key, undefined];\n } // END parseKeyWithTags\n\n for (const key in data) {\n const [name, tag] = parseKeyWithTags(key);\n // Start with path containing just the key name\n result[name] = decodeValue.call([name], name, tag, data[key]);\n }\n pointers2Res.forEach(changeAttributeReference.bind(null, result));\n return result;\n} // END decode\n\nfunction changeAttributeReference(obj, [refPath, attrPath]) {\n // refPath and attrPath are now arrays, no splitting needed\n const refKeys = refPath || [];\n const attrKeys = attrPath || [];\n\n // Get the reference target by traversing refPath\n let ref = obj;\n for (let i = 0; i < refKeys.length; i++) {\n ref = ref[refKeys[i]];\n }\n\n // Get the parent of the attribute to set\n let attr = obj;\n for (let i = 0; i < attrKeys.length - 1; i++) {\n attr = attr[attrKeys[i]];\n }\n\n // Set the attribute to point to the reference\n attr[attrKeys[attrKeys.length - 1]] = ref;\n return obj;\n} // END changeAttributeReference\n\n\nmodule.exports = { parse, stringify, encode, decode };\n", "import messageHash from '../utils/messageHash'\nimport jss from '../utils/jss'\nimport { createStreamingTransport } from './transports/streaming'\n\nlet connect;\n\n// Connection state enum\nconst ConnectionState = {\n Offline: 'offline', // navigator.onLine = false\n Walled: 'walled', // Captive portal detected (ping failed)\n Disconnected: 'disconnected',\n Connecting: 'connecting',\n Connected: 'connected',\n Closing: 'closing'\n}\n\n// Connection state tracking - start with offline check\nlet connectionState = (typeof navigator !== 'undefined' && !navigator.onLine)\n ? ConnectionState.Offline\n : ConnectionState.Disconnected\nconst connectionChangeListeners = []\n\nfunction notifyConnectionChange(newState) {\n if (connectionState !== newState) {\n connectionState = newState\n connectionChangeListeners.forEach(fn => fn(newState))\n }\n}\n\n// Configuration\nlet configuredTransport = 'auto' // 'auto' | 'websocket' | 'polling'\n\n// Transport state\nlet currentTransport = null // 'websocket' | 'polling'\nlet streamingTransport = null\nlet wsRetryTimer = null\nlet networkCheckTimer = null\nconst WS_FALLBACK_TIMEOUT = 4000 // Time to wait for WS before fallback\nconst WS_RETRY_INTERVAL = 30000 // Retry WebSocket while in polling mode\nconst PING_TIMEOUT = 3000 // Timeout for ping check\nconst MAX_PING_CLOCK_SKEW = 60000 // Max allowed time difference (60s)\n\n/**\n * Check if running in dev/local mode\n */\nfunction isDevMode() {\n if (typeof window === 'undefined') return false\n return ['localhost', '127.0.0.1', '[::1]'].includes(window.location.hostname)\n}\n\n/**\n * Build ping URL for captive portal detection\n */\nfunction getPingUrl() {\n const hostname = window.location.hostname\n const localServers = ['localhost', '127.0.0.1', '[::1]']\n const isLocal = localServers.includes(hostname)\n const isHttps = window.location.protocol === 'https:'\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? 'https' : 'http'\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : ''\n return `${protocol}://${hostname}${portSuffix}/api/ape/ping`\n}\n\n/**\n * Check for captive portal by pinging /api/ape/ping\n * Returns 'ok' if real internet, 'walled' if captive portal detected\n */\nasync function checkCaptivePortal() {\n try {\n const controller = new AbortController()\n const timeoutId = setTimeout(() => controller.abort(), PING_TIMEOUT)\n\n const response = await fetch(getPingUrl(), {\n cache: 'no-store',\n signal: controller.signal\n })\n clearTimeout(timeoutId)\n\n if (!response.ok) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed: HTTP', response.status)\n }\n return 'walled'\n }\n\n const data = await response.json()\n\n // Verify response is genuine (not a captive portal redirect page)\n if (data?.ok !== true) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed: invalid response', data)\n }\n return 'walled'\n }\n\n // Validate timestamp to detect proxy replay attacks\n if (typeof data.ts === 'number') {\n const now = Date.now()\n const skew = Math.abs(now - data.ts)\n if (skew > MAX_PING_CLOCK_SKEW) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed: timestamp too old/stale (skew:', skew, 'ms)')\n }\n return 'walled'\n }\n }\n\n return 'ok'\n } catch (err) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed:', err.message || err)\n }\n return 'walled'\n }\n}\n\n/**\n * Setup navigator.onLine event listeners\n */\nfunction setupOnlineListeners() {\n if (typeof window === 'undefined') return\n\n window.addEventListener('online', () => {\n console.log('\uD83E\uDD8D Browser went online, checking network...')\n // Trigger reconnection attempt\n attemptConnection()\n })\n\n window.addEventListener('offline', () => {\n console.log('\uD83E\uDD8D Browser went offline')\n notifyConnectionChange(ConnectionState.Offline)\n })\n}\n\n// Setup listeners on module load (browser only)\nif (typeof window !== 'undefined') {\n setupOnlineListeners()\n}\n\n\n\n/**\n * Get WebSocket URL - auto-detects from window.location, keeps /api/ape path\n */\nfunction getSocketUrl() {\n const hostname = window.location.hostname\n const localServers = [\"localhost\", \"127.0.0.1\", \"[::1]\"]\n const isLocal = localServers.includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n\n // Default port: 9010 for local dev, otherwise use window.location.port or implicit 443/80\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n\n // Build URL - keep /api/ape path\n const protocol = isHttps ? \"wss\" : \"ws\"\n const portSuffix = (isLocal || port !== 80 && port !== 443) ? `:${port}` : \"\"\n\n return `${protocol}://${hostname}${portSuffix}/api/ape`\n}\n\nlet reconnect = false\nconst connectTimeout = 5000\nconst totalRequestTimeout = 10000\n//const location = window.location\n\nconst joinKey = \"/\"\n// Properties accessed directly on `ape` that should NOT be intercepted\nconst reservedKeys = new Set(['on', 'onConnectionChange', 'transport'])\nconst handler = {\n get(fn, key) {\n // Skip proxy interception for reserved keys - return actual property\n if (reservedKeys.has(key)) {\n return fn[key]\n }\n const wrapperFn = function (a, b) {\n let path = joinKey + key, body;\n if (2 === arguments.length) {\n path += a\n body = b\n } else {\n body = a\n }\n return fn(path, body)\n }\n return new Proxy(wrapperFn, handler)\n } // END get\n}\n\nfunction wrap(api) {\n return new Proxy(api, handler)\n}\n\nlet __socket = false, ready = false, wsSend = false;\nconst waitingOn = {};\n\nlet aWaitingSend = []\nconst receiverArray = [];\nconst ofTypesOb = {};\n\n/**\n * Switch to streaming transport (HTTP long polling fallback)\n */\nfunction switchToStreaming() {\n console.log('\uD83E\uDD8D Switching to HTTP streaming transport')\n currentTransport = 'polling'\n\n if (!streamingTransport) {\n streamingTransport = createStreamingTransport()\n\n // Handle incoming messages from streaming transport\n streamingTransport.onMessage = async (msg) => {\n const { err, type, data } = msg\n\n // Process linked resources and shared files\n let processedData = data\n if (data && !err) {\n try {\n processedData = await fetchLinkedResources(data)\n processedData = await fetchSharedFiles(processedData)\n } catch (fetchErr) {\n console.error(`\uD83E\uDD8D Failed to hydrate streaming data:`, fetchErr)\n }\n }\n\n // Dispatch to type-specific handlers\n if (ofTypesOb[type]) {\n ofTypesOb[type].forEach(worker => worker({ err, type, data: processedData }))\n }\n // Dispatch to general handlers\n receiverArray.forEach(worker => worker({ err, type, data: processedData }))\n }\n\n streamingTransport.onOpen = () => {\n ready = true\n notifyConnectionChange(ConnectionState.Connected)\n console.log('\uD83E\uDD8D HTTP streaming connected')\n\n // Flush waiting messages\n aWaitingSend.forEach(({ type, data, resolve, reject, waiting, createdAt, timer }) => {\n clearTimeout(timer)\n const resultPromise = streamingSend(type, data, createdAt)\n if (waiting) {\n resultPromise.then(resolve).catch(reject)\n }\n })\n aWaitingSend = []\n\n // Start background WebSocket retry\n startWsRetry()\n }\n\n streamingTransport.onClose = () => {\n ready = false\n notifyConnectionChange(ConnectionState.Disconnected)\n }\n\n streamingTransport.onError = (err) => {\n console.error('\uD83E\uDD8D Streaming error:', err)\n }\n }\n\n streamingTransport.connect()\n}\n\n/**\n * Send via streaming transport\n */\nfunction streamingSend(type, data, createdAt) {\n return streamingTransport.send(type, data, createdAt)\n}\n\n/**\n * Start background retry for WebSocket (while in polling mode)\n */\nfunction startWsRetry() {\n if (wsRetryTimer) return\n if (currentTransport !== 'polling') return\n if (configuredTransport === 'polling') return // User explicitly wants polling only\n\n wsRetryTimer = setInterval(() => {\n if (currentTransport !== 'polling') {\n clearInterval(wsRetryTimer)\n wsRetryTimer = null\n return\n }\n\n console.log('\uD83E\uDD8D Attempting WebSocket reconnection...')\n tryWebSocket(true)\n }, WS_RETRY_INTERVAL)\n}\n\n/**\n * Try to establish WebSocket connection\n * @param {boolean} isRetry - If true, this is a background retry attempt\n */\nfunction tryWebSocket(isRetry = false) {\n const ws = new WebSocket(getSocketUrl())\n let fallbackTimer = null\n\n // Set fallback timeout (only for initial connection, not retries)\n if (!isRetry && configuredTransport === 'auto') {\n fallbackTimer = setTimeout(() => {\n if (ws.readyState !== WebSocket.OPEN) {\n console.log('\uD83E\uDD8D WebSocket timeout, falling back to HTTP streaming')\n ws.close()\n switchToStreaming()\n }\n }, WS_FALLBACK_TIMEOUT)\n }\n\n ws.onopen = () => {\n if (fallbackTimer) clearTimeout(fallbackTimer)\n\n // If this is a retry and we're in polling mode, switch back to WebSocket\n if (isRetry && currentTransport === 'polling') {\n console.log('\uD83E\uDD8D WebSocket reconnected, switching from HTTP streaming')\n if (streamingTransport) {\n streamingTransport.close()\n }\n if (wsRetryTimer) {\n clearInterval(wsRetryTimer)\n wsRetryTimer = null\n }\n }\n\n currentTransport = 'websocket'\n __socket = ws\n ready = true\n notifyConnectionChange(ConnectionState.Connected)\n\n aWaitingSend.forEach(({ type, data, resolve, reject, waiting, createdAt, timer }) => {\n clearTimeout(timer)\n const resultPromise = wsSend(type, data, createdAt)\n if (waiting) {\n resultPromise.then(resolve).catch(reject)\n }\n })\n aWaitingSend = []\n }\n\n ws.onmessage = async function (event) {\n const { err, type, queryId, data } = jss.parse(event.data)\n\n // Messages with queryId must fulfill matching promise\n if (queryId) {\n if (waitingOn[queryId]) {\n // Check for linked resources and fetch them before resolving\n if (data && !err) {\n try {\n let hydratedData = await fetchLinkedResources(data)\n hydratedData = await fetchSharedFiles(hydratedData)\n waitingOn[queryId](err, hydratedData)\n } catch (fetchErr) {\n waitingOn[queryId](fetchErr, null)\n }\n } else {\n waitingOn[queryId](err, data)\n }\n delete waitingOn[queryId]\n } else {\n console.error(`\uD83E\uDD8D No matching queryId: ${queryId}`)\n }\n return\n }\n\n // Only messages WITHOUT queryId go to setOnReceiver\n let processedData = data\n if (data && !err) {\n try {\n processedData = await fetchLinkedResources(data)\n processedData = await fetchSharedFiles(processedData)\n } catch (fetchErr) {\n console.error(`\uD83E\uDD8D Failed to hydrate broadcast data:`, fetchErr)\n }\n }\n\n if (ofTypesOb[type]) {\n ofTypesOb[type].forEach(worker => worker({ err, type, data: processedData }))\n }\n receiverArray.forEach(worker => worker({ err, type, data: processedData }))\n }\n\n ws.onerror = function (err) {\n if (fallbackTimer) clearTimeout(fallbackTimer)\n console.error('socket ERROR:', err)\n\n // On initial connection error in auto mode, fallback to streaming\n if (!isRetry && configuredTransport === 'auto' && !ready) {\n switchToStreaming()\n }\n }\n\n ws.onclose = function (event) {\n if (fallbackTimer) clearTimeout(fallbackTimer)\n console.warn('socket disconnect:', event)\n __socket = false\n ready = false\n\n // Only notify disconnected if we're on websocket transport\n if (currentTransport === 'websocket') {\n notifyConnectionChange(ConnectionState.Disconnected)\n setTimeout(() => reconnect && connectSocket(), 500)\n }\n }\n}\n\n/**\n * Find all L-tagged (binary link) properties in data\n * Returns array of { path, hash }\n */\nfunction findLinkedResources(obj, path = '') {\n const resources = []\n\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return resources\n }\n\n if (Array.isArray(obj)) {\n for (let i = 0; i < obj.length; i++) {\n resources.push(...findLinkedResources(obj[i], path ? `${path}.${i}` : String(i)))\n }\n return resources\n }\n\n for (const key of Object.keys(obj)) {\n // Check for L-tag in key (from JJS encoding: key<!L>)\n if (key.endsWith('<!L>')) {\n const cleanKey = key.slice(0, -4)\n const hash = obj[key]\n resources.push({\n path: path ? `${path}.${cleanKey}` : cleanKey,\n hash,\n originalKey: key\n })\n } else {\n resources.push(...findLinkedResources(obj[key], path ? `${path}.${key}` : key))\n }\n }\n\n return resources\n}\n\n/**\n * Find all F-tagged (shared file) properties in data\n * Returns array of { path, hash, originalKey }\n */\nfunction findFileTags(obj, path = '') {\n const files = []\n\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return files\n }\n\n if (Array.isArray(obj)) {\n for (let i = 0; i < obj.length; i++) {\n files.push(...findFileTags(obj[i], path ? `${path}.${i}` : String(i)))\n }\n return files\n }\n\n for (const key of Object.keys(obj)) {\n // Check for F-tag in key (client-to-client shared file marker)\n if (key.endsWith('<!F>')) {\n const cleanKey = key.slice(0, -4)\n const hash = obj[key]\n files.push({\n path: path ? `${path}.${cleanKey}` : cleanKey,\n hash,\n originalKey: key\n })\n } else {\n files.push(...findFileTags(obj[key], path ? `${path}.${key}` : key))\n }\n }\n\n return files\n}\n\n/**\n * Clean up F-tagged keys (rename key<!F> to key)\n */\nfunction cleanFileTags(obj) {\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return obj\n }\n\n if (Array.isArray(obj)) {\n return obj.map(cleanFileTags)\n }\n\n const cleaned = {}\n for (const key of Object.keys(obj)) {\n if (key.endsWith('<!F>')) {\n const cleanKey = key.slice(0, -4)\n cleaned[cleanKey] = obj[key]\n } else {\n cleaned[key] = cleanFileTags(obj[key])\n }\n }\n return cleaned\n}\n\n/**\n * Fetch shared files (client-to-client transfers)\n * Retries if upload is still in progress\n */\nasync function fetchSharedFiles(data, maxRetries = 5) {\n const files = findFileTags(data)\n\n if (files.length === 0) {\n return data\n }\n\n console.log(`\uD83E\uDD8D Fetching ${files.length} shared file(s)`)\n\n const cleanedData = cleanFileTags(data)\n\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n await Promise.all(files.map(async ({ path, hash }) => {\n let retries = 0\n let backoff = 100 // Start with 100ms\n\n while (retries < maxRetries) {\n try {\n const response = await fetch(`${baseUrl}/api/ape/data/${hash}`, {\n credentials: 'include'\n })\n\n if (!response.ok) {\n // 404 might mean file not uploaded yet, retry\n if (response.status === 404 && retries < maxRetries - 1) {\n retries++\n await new Promise(r => setTimeout(r, backoff))\n backoff *= 2 // Exponential backoff\n continue\n }\n throw new Error(`Failed to fetch shared file: ${response.status}`)\n }\n\n const arrayBuffer = await response.arrayBuffer()\n setValueAtPath(cleanedData, path, arrayBuffer)\n\n // Check if upload is still in progress\n const isComplete = response.headers.get('X-Ape-Complete') === '1'\n if (!isComplete) {\n console.log(`\uD83E\uDD8D Shared file ${hash} still uploading (${response.headers.get('X-Ape-Total-Received') || '?'} bytes)`)\n }\n break\n } catch (err) {\n if (retries >= maxRetries - 1) {\n console.error(`\uD83E\uDD8D Failed to fetch shared file at ${path}:`, err)\n setValueAtPath(cleanedData, path, null)\n }\n retries++\n await new Promise(r => setTimeout(r, backoff))\n backoff *= 2\n }\n }\n }))\n\n return cleanedData\n}\n\n/**\n * Set a value at a nested path in an object\n */\nfunction setValueAtPath(obj, path, value) {\n const parts = path.split('.')\n let current = obj\n\n for (let i = 0; i < parts.length - 1; i++) {\n current = current[parts[i]]\n }\n\n current[parts[parts.length - 1]] = value\n}\n\n/**\n * Clean up L-tagged keys (rename key<!L> to key)\n */\nfunction cleanLinkedKeys(obj) {\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return obj\n }\n\n if (Array.isArray(obj)) {\n return obj.map(cleanLinkedKeys)\n }\n\n const cleaned = {}\n for (const key of Object.keys(obj)) {\n if (key.endsWith('<!L>')) {\n const cleanKey = key.slice(0, -4)\n cleaned[cleanKey] = obj[key]\n } else {\n cleaned[key] = cleanLinkedKeys(obj[key])\n }\n }\n return cleaned\n}\n\n/**\n * Fetch binary resources and hydrate data object\n */\nasync function fetchLinkedResources(data, clientId) {\n const resources = findLinkedResources(data)\n\n if (resources.length === 0) {\n return data\n }\n\n console.log(`\uD83E\uDD8D Fetching ${resources.length} binary resource(s)`)\n\n const cleanedData = cleanLinkedKeys(data)\n\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n await Promise.all(resources.map(async ({ path, hash }) => {\n try {\n const response = await fetch(`${baseUrl}/api/ape/data/${hash}`, {\n credentials: 'include',\n headers: {\n 'X-Ape-Client-Id': clientId || ''\n }\n })\n\n if (!response.ok) {\n throw new Error(`Failed to fetch binary resource: ${response.status}`)\n }\n\n const arrayBuffer = await response.arrayBuffer()\n setValueAtPath(cleanedData, path, arrayBuffer)\n } catch (err) {\n console.error(`\uD83E\uDD8D Failed to fetch binary resource at ${path}:`, err)\n setValueAtPath(cleanedData, path, null)\n }\n }))\n\n return cleanedData\n}\n\n/**\n * Attempt to establish connection with network pre-checks\n */\nasync function attemptConnection() {\n // Check if browser is online\n if (typeof navigator !== 'undefined' && !navigator.onLine) {\n notifyConnectionChange(ConnectionState.Offline)\n return\n }\n\n // Perform captive portal check\n notifyConnectionChange(ConnectionState.Connecting)\n const pingResult = await checkCaptivePortal()\n\n if (pingResult === 'walled') {\n notifyConnectionChange(ConnectionState.Walled)\n // Retry network check periodically\n scheduleNetworkRetry()\n return\n }\n\n // Network is good, proceed with socket connection\n proceedWithConnection()\n}\n\n/**\n * Schedule a retry of network check (for walled/offline states)\n */\nfunction scheduleNetworkRetry() {\n if (networkCheckTimer) return\n networkCheckTimer = setTimeout(() => {\n networkCheckTimer = null\n attemptConnection()\n }, WS_RETRY_INTERVAL)\n}\n\n/**\n * Proceed with WebSocket/polling connection after network checks pass\n */\nfunction proceedWithConnection() {\n // Determine which transport to use\n if (configuredTransport === 'polling') {\n switchToStreaming()\n } else {\n // 'auto' or 'websocket' - try WebSocket first\n tryWebSocket(false)\n }\n}\n\nfunction connectSocket() {\n // Skip if already connected or connecting\n if (__socket && __socket.readyState !== WebSocket.CLOSED) {\n return buildClientInterface()\n }\n if (currentTransport === 'polling' && streamingTransport?.isConnected()) {\n return buildClientInterface()\n }\n if (connectionState === ConnectionState.Connecting) {\n return buildClientInterface()\n }\n\n // Start connection with network pre-checks\n attemptConnection()\n\n return buildClientInterface()\n}\n\n/**\n * Check if value is binary data (ArrayBuffer, typed array, or Blob)\n */\nfunction isBinaryData(value) {\n if (value === null || value === undefined) return false\n return value instanceof ArrayBuffer ||\n ArrayBuffer.isView(value) ||\n (typeof Blob !== 'undefined' && value instanceof Blob)\n}\n\n/**\n * Get binary type tag (A for ArrayBuffer, B for Blob)\n */\nfunction getBinaryTag(value) {\n if (typeof Blob !== 'undefined' && value instanceof Blob) return 'B'\n return 'A'\n}\n\n/**\n * Generate a simple hash for binary upload\n */\nfunction generateUploadHash(path) {\n let hash = 0\n for (let i = 0; i < path.length; i++) {\n const char = path.charCodeAt(i)\n hash = ((hash << 5) - hash) + char\n hash = hash & hash\n }\n return Math.abs(hash).toString(36)\n}\n\n/**\n * Find and extract binary data from payload\n * Returns { processedData, uploads: [{ path, hash, data, tag }] }\n */\nfunction processBinaryForUpload(data, path = '') {\n if (data === null || data === undefined) {\n return { processedData: data, uploads: [] }\n }\n\n if (isBinaryData(data)) {\n const tag = getBinaryTag(data)\n const hash = generateUploadHash(path || 'root')\n return {\n processedData: { [`__ape_upload__`]: hash },\n uploads: [{ path, hash, data, tag }]\n }\n }\n\n if (Array.isArray(data)) {\n const processedArray = []\n const allUploads = []\n\n for (let i = 0; i < data.length; i++) {\n const itemPath = path ? `${path}.${i}` : String(i)\n const { processedData, uploads } = processBinaryForUpload(data[i], itemPath)\n processedArray.push(processedData)\n allUploads.push(...uploads)\n }\n\n return { processedData: processedArray, uploads: allUploads }\n }\n\n if (typeof data === 'object') {\n const processedObj = {}\n const allUploads = []\n\n for (const key of Object.keys(data)) {\n const itemPath = path ? `${path}.${key}` : key\n const { processedData, uploads } = processBinaryForUpload(data[key], itemPath)\n\n // If this was binary data, mark the key with <!B> or <!A> tag\n if (uploads.length > 0 && processedData?.__ape_upload__) {\n const tag = uploads[uploads.length - 1].tag\n processedObj[`${key}<!${tag}>`] = processedData.__ape_upload__\n } else {\n processedObj[key] = processedData\n }\n allUploads.push(...uploads)\n }\n\n return { processedData: processedObj, uploads: allUploads }\n }\n\n return { processedData: data, uploads: [] }\n}\n\n/**\n * Find and extract binary data for SHARING (client-to-client)\n * Uses <!F> tag instead of <!A>/<!B>\n * Returns { processedData, shares: [{ path, hash, data }] }\n */\nfunction processBinaryForSharing(data, path = '') {\n if (data === null || data === undefined) {\n return { processedData: data, shares: [] }\n }\n\n if (isBinaryData(data)) {\n const hash = generateUploadHash(path || 'share')\n return {\n processedData: { [`__ape_share__`]: hash },\n shares: [{ path, hash, data }]\n }\n }\n\n if (Array.isArray(data)) {\n const processedArray = []\n const allShares = []\n\n for (let i = 0; i < data.length; i++) {\n const itemPath = path ? `${path}.${i}` : String(i)\n const { processedData, shares } = processBinaryForSharing(data[i], itemPath)\n processedArray.push(processedData)\n allShares.push(...shares)\n }\n\n return { processedData: processedArray, shares: allShares }\n }\n\n if (typeof data === 'object') {\n const processedObj = {}\n const allShares = []\n\n for (const key of Object.keys(data)) {\n const itemPath = path ? `${path}.${key}` : key\n const { processedData, shares } = processBinaryForSharing(data[key], itemPath)\n\n // If this was binary data, mark the key with <!F> tag\n if (shares.length > 0 && processedData?.__ape_share__) {\n processedObj[`${key}<!F>`] = processedData.__ape_share__\n } else {\n processedObj[key] = processedData\n }\n allShares.push(...shares)\n }\n\n return { processedData: processedObj, shares: allShares }\n }\n\n return { processedData: data, shares: [] }\n}\n\n/**\n * Upload shared files via HTTP PUT\n * Uses different endpoint pattern for streaming files\n */\nasync function uploadSharedFiles(shares) {\n if (shares.length === 0) return\n\n // Build base URL\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n console.log(`\uD83E\uDD8D Uploading ${shares.length} shared file(s)`)\n\n await Promise.all(shares.map(async ({ hash, data }) => {\n try {\n // For shared files, use upload pattern with hash as both queryId and pathHash\n const response = await fetch(`${baseUrl}/api/ape/data/_share/${hash}`, {\n method: 'PUT',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/octet-stream'\n },\n body: data\n })\n\n if (!response.ok) {\n throw new Error(`Shared upload failed: ${response.status}`)\n }\n } catch (err) {\n console.error(`\uD83E\uDD8D Failed to upload shared file ${hash}:`, err)\n throw err\n }\n }))\n}\n\n/**\n * Upload binary data via HTTP PUT\n */\nasync function uploadBinaryData(queryId, uploads) {\n if (uploads.length === 0) return\n\n // Build base URL\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n console.log(`\uD83E\uDD8D Uploading ${uploads.length} binary file(s)`)\n\n await Promise.all(uploads.map(async ({ hash, data }) => {\n try {\n const response = await fetch(`${baseUrl}/api/ape/data/${queryId}/${hash}`, {\n method: 'PUT',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/octet-stream'\n },\n body: data\n })\n\n if (!response.ok) {\n throw new Error(`Upload failed: ${response.status}`)\n }\n } catch (err) {\n console.error(`\uD83E\uDD8D Failed to upload binary at ${hash}:`, err)\n throw err\n }\n }))\n}\n\nwsSend = function (type, data, createdAt, dirctCall) {\n let rej, promiseIsLive = false;\n const timeLetForReqToBeMade = (createdAt + totalRequestTimeout) - Date.now()\n\n const timer = setTimeout(() => {\n if (promiseIsLive) {\n rej(new Error(\"Request Timedout for :\" + type))\n }\n }, timeLetForReqToBeMade);\n\n // Process binary data for upload\n const { processedData, uploads } = processBinaryForUpload(data)\n\n const payload = {\n type,\n data: processedData,\n //referer:window.location.href,\n createdAt: new Date(createdAt),\n requestedAt: dirctCall ? undefined\n : new Date()\n }\n const message = jss.stringify(payload)\n const queryId = messageHash(message);\n\n const replyPromise = new Promise((resolve, reject) => {\n rej = reject\n waitingOn[queryId] = (err, result) => {\n clearTimeout(timer)\n replyPromise.then = next.bind(replyPromise)\n if (err) {\n reject(err)\n } else {\n resolve(result)\n }\n }\n __socket.send(message);\n\n // Upload binary data after sending WS message\n if (uploads.length > 0) {\n uploadBinaryData(queryId, uploads).catch(err => {\n console.error('\uD83E\uDD8D Binary upload failed:', err)\n // The server will timeout waiting for the upload\n })\n }\n });\n const next = replyPromise.then;\n replyPromise.then = worker => {\n promiseIsLive = true;\n replyPromise.then = next.bind(replyPromise)\n replyPromise.catch = err.bind(replyPromise)\n return next.call(replyPromise, worker)\n }\n const err = replyPromise.catch;\n replyPromise.catch = worker => {\n promiseIsLive = true;\n replyPromise.catch = err.bind(replyPromise)\n replyPromise.then = next.bind(replyPromise)\n return err.call(replyPromise, worker)\n }\n return replyPromise\n} // END wsSend\n\n\nconst sender = (type, data) => {\n if (\"string\" !== typeof type) {\n throw new Error(\"Missing Path vaule\")\n }\n\n const createdAt = Date.now()\n\n if (ready) {\n return wsSend(type, data, createdAt, true)\n }\n\n const timeLetForReqToBeMade = (createdAt + connectTimeout) - Date.now() // 5sec for reconnect\n\n const timer = setTimeout(() => {\n const errMessage = \"Request not sent for :\" + type\n if (payload.waiting) {\n payload.reject(new Error(errMessage))\n } else {\n throw new Error(errMessage)\n }\n }, timeLetForReqToBeMade);\n\n const payload = { type, data, resolve: undefined, reject: undefined, waiting: false, createdAt, timer };\n const waitingOnOpen = new Promise((res, rej) => { payload.resolve = res; payload.reject = rej; })\n\n const waitingOnOpenThen = waitingOnOpen.then;\n const waitingOnOpenCatch = waitingOnOpen.catch;\n waitingOnOpen.then = worker => {\n payload.waiting = true;\n waitingOnOpen.then = waitingOnOpenThen.bind(waitingOnOpen)\n waitingOnOpen.catch = waitingOnOpenCatch.bind(waitingOnOpen)\n return waitingOnOpenThen.call(waitingOnOpen, worker)\n }\n waitingOnOpen.catch = worker => {\n payload.waiting = true;\n waitingOnOpen.catch = waitingOnOpenCatch.bind(waitingOnOpen)\n waitingOnOpen.then = waitingOnOpenThen.bind(waitingOnOpen)\n return waitingOnOpenCatch.call(waitingOnOpen, worker)\n }\n\n aWaitingSend.push(payload)\n if (!__socket) {\n connectSocket()\n }\n\n return waitingOnOpen\n} // END sender\n\n/**\n * Build the client interface object\n */\nfunction buildClientInterface() {\n return {\n sender: wrap(sender),\n setOnReceiver: (onTypeStFn, handlerFn) => {\n if (\"string\" === typeof onTypeStFn) {\n // Replace handler for this type (prevents duplicates in React StrictMode)\n ofTypesOb[onTypeStFn] = [handlerFn]\n } else {\n // For general receivers, prevent duplicates by checking\n if (!receiverArray.includes(onTypeStFn)) {\n receiverArray.push(onTypeStFn)\n }\n }\n },\n onConnectionChange: (handler) => {\n connectionChangeListeners.push(handler)\n // Immediately call with current state\n handler(connectionState)\n // Return unsubscribe function\n return () => {\n const idx = connectionChangeListeners.indexOf(handler)\n if (idx > -1) connectionChangeListeners.splice(idx, 1)\n }\n },\n // Expose current transport type (read-only)\n get transport() { return currentTransport }\n }\n}\n\nconnectSocket.autoReconnect = () => reconnect = true\nconnectSocket.ConnectionState = ConnectionState\nconnect = connectSocket\n\nexport default connect;\nexport { ConnectionState };\n", "import jss from '../../utils/jss'\n\n/**\n * HTTP Streaming transport - fallback when WebSocket is blocked\n * Uses fetch + ReadableStream for receiving, POST for sending\n */\n\n/**\n * Get base URL for polling endpoints\n */\nfunction getPollUrl() {\n const hostname = window.location.hostname\n const localServers = [\"localhost\", \"127.0.0.1\", \"[::1]\"]\n const isLocal = localServers.includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n\n return `${protocol}://${hostname}${portSuffix}/api/ape/poll`\n}\n\n/**\n * Parse JSON objects from a streaming buffer by counting braces\n * Handles strings containing braces correctly\n */\nfunction parseStreamBuffer(buffer) {\n const messages = []\n let start = -1\n let depth = 0\n let inString = false\n let escaped = false\n\n for (let i = 0; i < buffer.length; i++) {\n const char = buffer[i]\n\n if (escaped) {\n escaped = false\n continue\n }\n\n if (char === '\\\\' && inString) {\n escaped = true\n continue\n }\n\n if (char === '\"') {\n inString = !inString\n continue\n }\n\n if (inString) continue\n\n if (char === '{') {\n if (depth === 0) {\n start = i\n }\n depth++\n } else if (char === '}') {\n depth--\n if (depth === 0 && start !== -1) {\n const jsonStr = buffer.slice(start, i + 1)\n try {\n messages.push(jss.parse(jsonStr))\n } catch (e) {\n console.error('\uD83E\uDD8D Failed to parse stream message:', e)\n }\n start = -1\n }\n }\n }\n\n // Return remaining buffer (incomplete message)\n const remaining = start !== -1 ? buffer.slice(start) : ''\n return { messages, remaining }\n}\n\n/**\n * Create streaming transport instance\n */\nfunction createStreamingTransport() {\n let isActive = false\n let abortController = null\n let streamBuffer = ''\n let reconnectTimer = null\n\n // Callbacks\n let onMessage = () => { }\n let onOpen = () => { }\n let onClose = () => { }\n let onError = () => { }\n\n /**\n * Start the streaming connection\n */\n async function connect() {\n if (isActive) return\n\n isActive = true\n abortController = new AbortController()\n\n try {\n const response = await fetch(getPollUrl(), {\n method: 'GET',\n credentials: 'include',\n signal: abortController.signal,\n headers: {\n 'Accept': 'application/json'\n }\n })\n\n if (!response.ok) {\n throw new Error(`Stream connect failed: ${response.status}`)\n }\n\n onOpen()\n\n const reader = response.body.getReader()\n const decoder = new TextDecoder()\n\n async function read() {\n while (isActive) {\n try {\n const { done, value } = await reader.read()\n\n if (done) {\n // Stream ended - reconnect\n scheduleReconnect()\n return\n }\n\n streamBuffer += decoder.decode(value, { stream: true })\n const { messages, remaining } = parseStreamBuffer(streamBuffer)\n streamBuffer = remaining\n\n for (const msg of messages) {\n // Skip heartbeat messages\n if (msg.type === '__heartbeat__') continue\n onMessage(msg)\n }\n } catch (readErr) {\n if (readErr.name === 'AbortError') return\n console.error('\uD83E\uDD8D Stream read error:', readErr)\n scheduleReconnect()\n return\n }\n }\n }\n\n read()\n\n } catch (err) {\n if (err.name === 'AbortError') return\n\n console.error('\uD83E\uDD8D Stream connection error:', err)\n onError(err)\n scheduleReconnect()\n }\n }\n\n /**\n * Schedule reconnection with small delay\n */\n function scheduleReconnect() {\n if (!isActive) return\n\n if (reconnectTimer) {\n clearTimeout(reconnectTimer)\n }\n\n reconnectTimer = setTimeout(() => {\n if (isActive) {\n connect()\n }\n }, 500)\n }\n\n /**\n * Send a message via POST\n */\n async function send(type, data, createdAt) {\n const payload = {\n type,\n data,\n createdAt: new Date(createdAt)\n }\n\n const response = await fetch(getPollUrl(), {\n method: 'POST',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: jss.stringify(payload)\n })\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({ error: 'Unknown error' }))\n throw new Error(error.error || `Request failed: ${response.status}`)\n }\n\n const result = jss.parse(await response.text())\n return result.data\n }\n\n /**\n * Close the streaming connection\n */\n function close() {\n isActive = false\n\n if (reconnectTimer) {\n clearTimeout(reconnectTimer)\n reconnectTimer = null\n }\n\n if (abortController) {\n abortController.abort()\n abortController = null\n }\n\n streamBuffer = ''\n onClose()\n }\n\n return {\n connect,\n send,\n close,\n isConnected: () => isActive,\n set onMessage(fn) { onMessage = fn },\n set onOpen(fn) { onOpen = fn },\n set onClose(fn) { onClose = fn },\n set onError(fn) { onError = fn }\n }\n}\n\nexport { createStreamingTransport, getPollUrl }\n", "import connectSocket from './connectSocket.js'\n\nconst client = connectSocket()\nconnectSocket.autoReconnect()\n\n// Global API - use defineProperty to bypass Proxy interception\nwindow.api = client.sender\nObject.defineProperty(window.api, 'on', {\n value: client.setOnReceiver,\n writable: false,\n enumerable: false,\n configurable: false\n})\nObject.defineProperty(window.api, 'onConnectionChange', {\n value: client.onConnectionChange,\n writable: false,\n enumerable: false,\n configurable: false\n})\n// Read-only transport property - only ape can change this internally\nObject.defineProperty(window.api, 'transport', {\n get: () => client.transport,\n enumerable: false,\n configurable: false\n})\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["require_messageHash", "__commonJSMin", "exports", "module", "alphabet", "toBase32", "n", "remainder", "current", "jenkinsOneAtATimeHash", "keyString", "hash", "charIndex", "messageHash", "messageSt", "require_jss", "__commonJSMin", "exports", "module", "encode", "obj", "tagLookup", "visited", "encodeValue", "value", "path", "type", "tag", "visitedEncode", "isArray", "keys", "result", "typesFound", "i", "key", "t", "v", "encodeValueWithVisited", "objKeys", "stringify", "parse", "encoded", "decode", "data", "pointers2Res", "s", "n", "sourceToPointAt", "replaceAtThisPlace", "name", "message", "stack", "err", "a", "o", "decodeValue", "val", "currentPath", "typeTags", "res", "itemPath", "decodedValue", "nam", "parseKeyWithTags", "match", "multiMatch", "arrayMatch", "changeAttributeReference", "refPath", "attrPath", "refKeys", "attrKeys", "ref", "attr", "import_messageHash", "import_jss", "import_jss", "getPollUrl", "hostname", "isLocal", "isHttps", "port", "protocol", "portSuffix", "parseStreamBuffer", "buffer", "messages", "start", "depth", "inString", "escaped", "i", "char", "jsonStr", "jss", "e", "remaining", "createStreamingTransport", "isActive", "abortController", "streamBuffer", "reconnectTimer", "onMessage", "onOpen", "onClose", "onError", "connect", "response", "reader", "decoder", "read", "done", "value", "scheduleReconnect", "msg", "readErr", "err", "send", "type", "data", "createdAt", "payload", "error", "close", "fn", "connect", "ConnectionState", "connectionState", "connectionChangeListeners", "notifyConnectionChange", "newState", "fn", "configuredTransport", "currentTransport", "streamingTransport", "wsRetryTimer", "networkCheckTimer", "WS_FALLBACK_TIMEOUT", "WS_RETRY_INTERVAL", "PING_TIMEOUT", "MAX_PING_CLOCK_SKEW", "isDevMode", "getPingUrl", "hostname", "
|
|
4
|
+
"sourcesContent": ["const alphabet = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\"\n/*\nfunction charValue(char){\n return alphabet.indexOf(char.toUpperCase())\n} // END charValue\n\nfunction fromBase32(b32){\n if (0 === b32.length) {\n return 0\n }\n return charValue(b32.slice(-1)) + fromBase32(b32.slice(0,-1)) * 32\n} // END fromBase32\n*/\nfunction toBase32 (n){\n const remainder = Math.floor(n/32)\n const current = n % 32\n if (0 === remainder) {\n return alphabet[current]\n }\n return toBase32(remainder)+alphabet[current]\n} // END toBase32\n\nfunction jenkinsOneAtATimeHash(keyString){\n \n var hash = 0\n \n for (var charIndex = 0; charIndex < keyString.length; ++charIndex)\n {\n hash += keyString.charCodeAt(charIndex);\n hash += hash << 10;\n hash ^= hash >> 6;\n }\n hash += hash << 3;\n hash ^= hash >> 11;\n //4,294,967,295 is FFFFFFFF, the maximum 32 bit unsigned integer value, used here as a mask.\n return (((hash + (hash << 15)) & 4294967295) >>> 0)\n} // END jenkinsOneAtATimeHash\n\nfunction messageHash(messageSt){\n return toBase32(jenkinsOneAtATimeHash(messageSt))\n} // END messageHash\n\nmodule.exports = messageHash", "//JsonSuperSet\n\n// TODO: add tests\n// check for any repeated ref not just cyclical references\n// support nasted array a<![,,[D]]>:[\"a\",\"b\",[Date]]\n// support array for the same type a<![*D]>:[Date,Date,Date]\n\nfunction encode(obj) {\n const tagLookup = {\n '[object RegExp]': 'R',\n '[object Date]': 'D',\n '[object Error]': 'E',\n \"[object Undefined]\": 'U',\n \"[object Map]\": 'M',\n \"[object Set]\": 'S',\n };\n const visited = new WeakMap();\n\n function encodeValue(value, path = '') {\n const type = typeof value;\n const tag = tagLookup[Object.prototype.toString.call(value)];\n // console.log({tag,value,path})\n if (tag !== undefined) {\n if ('D' === tag) return [tag, value.valueOf()];\n if ('E' === tag) return [tag, [value.name, value.message, value.stack]];\n if ('R' === tag) return [tag, value.toString()];\n if ('U' === tag) return [tag, null];\n if ('S' === tag) return [tag, Array.from(value)];\n if ('M' === tag) return [tag, Object.fromEntries(value)];\n\n return [tag, JSON.stringify(value)];\n } else if (type === 'object' && value !== null) {\n /*if (value.$ID) {\n return ['', value.$ID];\n }*/\n if (visitedEncode.has(value)) {\n return ['P', visitedEncode.get(value)];\n }\n visitedEncode.set(value, path);\n const isArray = Array.isArray(value);\n // keep index with undefined in Array\n const keys = isArray ? Array.from(Array(value.length).keys()) : Object.keys(value);\n const result = isArray ? [] : {};\n const typesFound = [];\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const [t, v] = encodeValue(value[key], key);\n // console.log([t, v])\n if (isArray) {\n typesFound.push(t);\n result.push(v);\n // remove key with undefined from Objects\n } else if (value[key] !== undefined) {\n result[key + (t ? `<!${t}>` : '')] = v;\n }\n }\n\n visited.delete(value);\n if (isArray && typesFound.find((t) => !!t)) {\n return [`[${typesFound.join()}]`, result];\n }\n return ['', result];\n } else {\n return ['', value];\n }\n } // END encodeValue\n\n let keys = [];\n // console.log(obj)\n if (Array.isArray(obj)) {\n keys = Array.from(Array(obj.length).keys())\n } else {\n keys = Object.keys(obj);\n }\n\n // Track root object to handle self-references\n const visitedEncode = new WeakMap();\n visitedEncode.set(obj, []); // Root path is empty array\n\n function encodeValueWithVisited(value, path = []) {\n const type = typeof value;\n const tag = tagLookup[Object.prototype.toString.call(value)];\n if (tag !== undefined) {\n if ('D' === tag) return [tag, value.valueOf()];\n if ('E' === tag) return [tag, [value.name, value.message, value.stack]];\n if ('R' === tag) return [tag, value.toString()];\n if ('U' === tag) return [tag, null];\n if ('S' === tag) return [tag, Array.from(value)];\n if ('M' === tag) return [tag, Object.fromEntries(value)];\n return [tag, JSON.stringify(value)];\n } else if (type === 'object' && value !== null) {\n if (visitedEncode.has(value)) {\n return ['P', visitedEncode.get(value)]; // Return array path\n }\n visitedEncode.set(value, path);\n const isArray = Array.isArray(value);\n const objKeys = isArray ? Array.from(Array(value.length).keys()) : Object.keys(value);\n const result = isArray ? [] : {};\n const typesFound = [];\n for (let i = 0; i < objKeys.length; i++) {\n const key = objKeys[i];\n const [t, v] = encodeValueWithVisited(value[key], [...path, key]); // Append key to path array\n if (isArray) {\n typesFound.push(t);\n result.push(v);\n } else if (value[key] !== undefined) {\n result[key + (t ? `<!${t}>` : '')] = v;\n }\n }\n if (isArray && typesFound.find((t) => !!t)) {\n return [`[${typesFound.join()}]`, result];\n }\n return ['', result];\n } else {\n return ['', value];\n }\n }\n\n const result = {};\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n // remove key with undefined from Objects\n if (obj[key] !== undefined) {\n const [t, v] = encodeValueWithVisited(obj[key], [key]); // Start path with single key\n result[key + (t ? `<!${t}>` : '')] = v;\n }\n }\n return result;\n} // END encode\n\nfunction stringify(obj) {\n return JSON.stringify(encode(obj))\n}\n\n\nfunction parse(encoded) {\n return decode(JSON.parse(encoded))\n}\n\nfunction decode(data) {\n const result = {};\n const pointers2Res = [];\n const tagLookup = {\n R: (s) => new RegExp(s),\n D: (n) => new Date(n),\n P: function (sourceToPointAt, replaceAtThisPlace) {\n // Both paths are now arrays\n pointers2Res.push([sourceToPointAt, replaceAtThisPlace]);\n return null; // Placeholder, will be replaced by changeAttributeReference\n },\n E: ([name, message, stack]) => {\n let err;\n try {\n err = new global[name](message);\n if (err instanceof Error) err.stack = stack;\n else throw {};\n } catch (e) {\n err = new Error(message);\n err.name = name;\n err.stack = stack;\n }\n return err;\n },\n U: () => undefined,\n S: (a) => new Set(a),\n M: (o) => new Map(Object.entries(o))\n };\n const visited = new Map();\n\n function decodeValue(name, tag, val) {\n // this is now an array path\n const currentPath = Array.isArray(this) ? this : [];\n\n if (tag in tagLookup) {\n return tagLookup[tag](val, currentPath);\n } else if (Array.isArray(val)) {\n if (tag && tag.startsWith('[')) {\n const typeTags = tag.slice(1, -1).split(',');\n const res = [];\n for (let i = 0; i < val.length; i++) {\n // Pass path with array index appended\n const itemPath = [...currentPath, i];\n const decodedValue = decodeValue.call(\n itemPath,\n i.toString(),\n typeTags[i],\n val[i]\n );\n res.push(decodedValue);\n }\n return res;\n } else {\n const res = [];\n for (let i = 0; i < val.length; i++) {\n const decodedValue = decodeValue.call([...currentPath, i], '', '', val[i]);\n res.push(decodedValue);\n }\n return res;\n }\n } else if ('object' === typeof val && val !== null) {\n if (visited.has(val)) {\n return visited.get(val);\n }\n visited.set(val, {});\n const res = {};\n for (const key in val) {\n const [nam, t] = parseKeyWithTags(key);\n const decodedValue = decodeValue.call(\n [...currentPath, nam],\n nam,\n t,\n val[key]\n );\n res[nam] = decodedValue;\n }\n visited.set(val, res);\n return res;\n } else {\n return val;\n }\n } // END decodeValue\n\n function parseKeyWithTags(key) {\n const match = key.match(/(.+)(<!(.)>)/);\n if (match) {\n return [match[1], match[3]];\n }\n // Try multi-character tags like array types [,D,]\n const multiMatch = key.match(/(.+)(<!!(.+)>)/);\n if (multiMatch) {\n return [multiMatch[1], multiMatch[3]];\n }\n // Also handle array type tags that start with [\n const arrayMatch = key.match(/(.+)(<!\\[(.*)>)/);\n if (arrayMatch) {\n return [arrayMatch[1], '[' + arrayMatch[3]];\n }\n return [key, undefined];\n } // END parseKeyWithTags\n\n for (const key in data) {\n const [name, tag] = parseKeyWithTags(key);\n // Start with path containing just the key name\n result[name] = decodeValue.call([name], name, tag, data[key]);\n }\n pointers2Res.forEach(changeAttributeReference.bind(null, result));\n return result;\n} // END decode\n\nfunction changeAttributeReference(obj, [refPath, attrPath]) {\n // refPath and attrPath are now arrays, no splitting needed\n const refKeys = refPath || [];\n const attrKeys = attrPath || [];\n\n // Get the reference target by traversing refPath\n let ref = obj;\n for (let i = 0; i < refKeys.length; i++) {\n ref = ref[refKeys[i]];\n }\n\n // Get the parent of the attribute to set\n let attr = obj;\n for (let i = 0; i < attrKeys.length - 1; i++) {\n attr = attr[attrKeys[i]];\n }\n\n // Set the attribute to point to the reference\n attr[attrKeys[attrKeys.length - 1]] = ref;\n return obj;\n} // END changeAttributeReference\n\n\nmodule.exports = { parse, stringify, encode, decode };\n", "import messageHash from '../utils/messageHash'\nimport jss from '../utils/jss'\nimport { createStreamingTransport } from './transports/streaming'\n\nlet connect;\n\n// Connection state enum\nconst ConnectionState = {\n Offline: 'offline', // navigator.onLine = false\n Walled: 'walled', // Captive portal detected (ping failed)\n Disconnected: 'disconnected',\n Connecting: 'connecting',\n Connected: 'connected',\n Closing: 'closing'\n}\n\n// Connection state tracking - start with offline check\nlet connectionState = (typeof navigator !== 'undefined' && !navigator.onLine)\n ? ConnectionState.Offline\n : ConnectionState.Disconnected\nconst connectionChangeListeners = []\n\nfunction notifyConnectionChange(newState) {\n if (connectionState !== newState) {\n connectionState = newState\n connectionChangeListeners.forEach(fn => fn(newState))\n }\n}\n\n// Configuration\nlet configuredTransport = 'auto' // 'auto' | 'websocket' | 'polling'\n\n// Transport state\nlet currentTransport = null // 'websocket' | 'polling'\nlet streamingTransport = null\nlet wsRetryTimer = null\nlet networkCheckTimer = null\nconst WS_FALLBACK_TIMEOUT = 4000 // Time to wait for WS before fallback\nconst WS_RETRY_INTERVAL = 30000 // Retry WebSocket while in polling mode\nconst PING_TIMEOUT = 3000 // Timeout for ping check\nconst MAX_PING_CLOCK_SKEW = 60000 // Max allowed time difference (60s)\n\n/**\n * Check if running in dev/local mode\n */\nfunction isDevMode() {\n if (typeof window === 'undefined') return false\n return ['localhost', '127.0.0.1', '[::1]'].includes(window.location.hostname)\n}\n\n/**\n * Build ping URL for captive portal detection\n */\nfunction getPingUrl() {\n const hostname = window.location.hostname\n const isHttps = window.location.protocol === 'https:'\n const port = window.location.port || (isHttps ? 443 : 80)\n const protocol = isHttps ? 'https' : 'http'\n const portSuffix = (port !== 80 && port !== 443) ? `:${port}` : ''\n return `${protocol}://${hostname}${portSuffix}/api/ape/ping`\n}\n\n/**\n * Check for captive portal by pinging /api/ape/ping\n * Returns 'ok' if real internet, 'walled' if captive portal detected\n */\nasync function checkCaptivePortal() {\n try {\n const controller = new AbortController()\n const timeoutId = setTimeout(() => controller.abort(), PING_TIMEOUT)\n\n const response = await fetch(getPingUrl(), {\n cache: 'no-store',\n signal: controller.signal\n })\n clearTimeout(timeoutId)\n\n if (!response.ok) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed: HTTP', response.status)\n }\n return 'walled'\n }\n\n const data = await response.json()\n\n // Verify response is genuine (not a captive portal redirect page)\n if (data?.ok !== true) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed: invalid response', data)\n }\n return 'walled'\n }\n\n // Validate timestamp to detect proxy replay attacks\n if (typeof data.ts === 'number') {\n const now = Date.now()\n const skew = Math.abs(now - data.ts)\n if (skew > MAX_PING_CLOCK_SKEW) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed: timestamp too old/stale (skew:', skew, 'ms)')\n }\n return 'walled'\n }\n }\n\n return 'ok'\n } catch (err) {\n if (isDevMode()) {\n console.error('\uD83E\uDD8D [DEV] Ping failed:', err.message || err)\n }\n return 'walled'\n }\n}\n\n/**\n * Setup navigator.onLine event listeners\n */\nfunction setupOnlineListeners() {\n if (typeof window === 'undefined') return\n\n window.addEventListener('online', () => {\n console.log('\uD83E\uDD8D Browser went online, checking network...')\n // Trigger reconnection attempt\n attemptConnection()\n })\n\n window.addEventListener('offline', () => {\n console.log('\uD83E\uDD8D Browser went offline')\n notifyConnectionChange(ConnectionState.Offline)\n })\n}\n\n// Setup listeners on module load (browser only)\nif (typeof window !== 'undefined') {\n setupOnlineListeners()\n}\n\n\n\n/**\n * Get WebSocket URL - auto-detects from window.location, keeps /api/ape path\n */\nfunction getSocketUrl() {\n const hostname = window.location.hostname\n const localServers = [\"localhost\", \"127.0.0.1\", \"[::1]\"]\n const isLocal = localServers.includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n\n // Default port: 9010 for local dev, otherwise use window.location.port or implicit 443/80\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n\n // Build URL - keep /api/ape path\n const protocol = isHttps ? \"wss\" : \"ws\"\n const portSuffix = (isLocal || port !== 80 && port !== 443) ? `:${port}` : \"\"\n\n return `${protocol}://${hostname}${portSuffix}/api/ape`\n}\n\nlet reconnect = false\nconst connectTimeout = 5000\nconst totalRequestTimeout = 10000\n//const location = window.location\n\nconst joinKey = \"/\"\n// Properties accessed directly on `ape` that should NOT be intercepted\nconst reservedKeys = new Set(['on', 'onConnectionChange', 'transport'])\nconst handler = {\n get(fn, key) {\n // Skip proxy interception for reserved keys - return actual property\n if (reservedKeys.has(key)) {\n return fn[key]\n }\n const wrapperFn = function (a, b) {\n let path = joinKey + key, body;\n if (2 === arguments.length) {\n path += a\n body = b\n } else {\n body = a\n }\n return fn(path, body)\n }\n return new Proxy(wrapperFn, handler)\n } // END get\n}\n\nfunction wrap(api) {\n return new Proxy(api, handler)\n}\n\nlet __socket = false, ready = false, wsSend = false;\nconst waitingOn = {};\n\nlet aWaitingSend = []\nconst receiverArray = [];\nconst ofTypesOb = {};\n\n/**\n * Switch to streaming transport (HTTP long polling fallback)\n */\nfunction switchToStreaming() {\n console.log('\uD83E\uDD8D Switching to HTTP streaming transport')\n currentTransport = 'polling'\n\n if (!streamingTransport) {\n streamingTransport = createStreamingTransport()\n\n // Handle incoming messages from streaming transport\n streamingTransport.onMessage = async (msg) => {\n const { err, type, data } = msg\n\n // Process linked resources and shared files\n let processedData = data\n if (data && !err) {\n try {\n processedData = await fetchLinkedResources(data)\n processedData = await fetchSharedFiles(processedData)\n } catch (fetchErr) {\n console.error(`\uD83E\uDD8D Failed to hydrate streaming data:`, fetchErr)\n }\n }\n\n // Dispatch to type-specific handlers\n if (ofTypesOb[type]) {\n ofTypesOb[type].forEach(worker => worker({ err, type, data: processedData }))\n }\n // Dispatch to general handlers\n receiverArray.forEach(worker => worker({ err, type, data: processedData }))\n }\n\n streamingTransport.onOpen = () => {\n ready = true\n notifyConnectionChange(ConnectionState.Connected)\n console.log('\uD83E\uDD8D HTTP streaming connected')\n\n // Flush waiting messages\n aWaitingSend.forEach(({ type, data, resolve, reject, waiting, createdAt, timer }) => {\n clearTimeout(timer)\n const resultPromise = streamingSend(type, data, createdAt)\n if (waiting) {\n resultPromise.then(resolve).catch(reject)\n }\n })\n aWaitingSend = []\n\n // Start background WebSocket retry\n startWsRetry()\n }\n\n streamingTransport.onClose = () => {\n ready = false\n notifyConnectionChange(ConnectionState.Disconnected)\n }\n\n streamingTransport.onError = (err) => {\n console.error('\uD83E\uDD8D Streaming error:', err)\n }\n }\n\n streamingTransport.connect()\n}\n\n/**\n * Send via streaming transport\n */\nfunction streamingSend(type, data, createdAt) {\n return streamingTransport.send(type, data, createdAt)\n}\n\n/**\n * Start background retry for WebSocket (while in polling mode)\n */\nfunction startWsRetry() {\n if (wsRetryTimer) return\n if (currentTransport !== 'polling') return\n if (configuredTransport === 'polling') return // User explicitly wants polling only\n\n wsRetryTimer = setInterval(() => {\n if (currentTransport !== 'polling') {\n clearInterval(wsRetryTimer)\n wsRetryTimer = null\n return\n }\n\n console.log('\uD83E\uDD8D Attempting WebSocket reconnection...')\n tryWebSocket(true)\n }, WS_RETRY_INTERVAL)\n}\n\n/**\n * Try to establish WebSocket connection\n * @param {boolean} isRetry - If true, this is a background retry attempt\n */\nfunction tryWebSocket(isRetry = false) {\n const ws = new WebSocket(getSocketUrl())\n let fallbackTimer = null\n\n // Set fallback timeout (only for initial connection, not retries)\n if (!isRetry && configuredTransport === 'auto') {\n fallbackTimer = setTimeout(() => {\n if (ws.readyState !== WebSocket.OPEN) {\n console.log('\uD83E\uDD8D WebSocket timeout, falling back to HTTP streaming')\n ws.close()\n switchToStreaming()\n }\n }, WS_FALLBACK_TIMEOUT)\n }\n\n ws.onopen = () => {\n if (fallbackTimer) clearTimeout(fallbackTimer)\n\n // If this is a retry and we're in polling mode, switch back to WebSocket\n if (isRetry && currentTransport === 'polling') {\n console.log('\uD83E\uDD8D WebSocket reconnected, switching from HTTP streaming')\n if (streamingTransport) {\n streamingTransport.close()\n }\n if (wsRetryTimer) {\n clearInterval(wsRetryTimer)\n wsRetryTimer = null\n }\n }\n\n currentTransport = 'websocket'\n __socket = ws\n ready = true\n notifyConnectionChange(ConnectionState.Connected)\n\n aWaitingSend.forEach(({ type, data, resolve, reject, waiting, createdAt, timer }) => {\n clearTimeout(timer)\n const resultPromise = wsSend(type, data, createdAt)\n if (waiting) {\n resultPromise.then(resolve).catch(reject)\n }\n })\n aWaitingSend = []\n }\n\n ws.onmessage = async function (event) {\n const { err, type, queryId, data } = jss.parse(event.data)\n\n // Messages with queryId must fulfill matching promise\n if (queryId) {\n if (waitingOn[queryId]) {\n // Check for linked resources and fetch them before resolving\n if (data && !err) {\n try {\n let hydratedData = await fetchLinkedResources(data)\n hydratedData = await fetchSharedFiles(hydratedData)\n waitingOn[queryId](err, hydratedData)\n } catch (fetchErr) {\n waitingOn[queryId](fetchErr, null)\n }\n } else {\n waitingOn[queryId](err, data)\n }\n delete waitingOn[queryId]\n } else {\n console.error(`\uD83E\uDD8D No matching queryId: ${queryId}`)\n }\n return\n }\n\n // Only messages WITHOUT queryId go to setOnReceiver\n let processedData = data\n if (data && !err) {\n try {\n processedData = await fetchLinkedResources(data)\n processedData = await fetchSharedFiles(processedData)\n } catch (fetchErr) {\n console.error(`\uD83E\uDD8D Failed to hydrate broadcast data:`, fetchErr)\n }\n }\n\n if (ofTypesOb[type]) {\n ofTypesOb[type].forEach(worker => worker({ err, type, data: processedData }))\n }\n receiverArray.forEach(worker => worker({ err, type, data: processedData }))\n }\n\n ws.onerror = function (err) {\n if (fallbackTimer) clearTimeout(fallbackTimer)\n console.error('socket ERROR:', err)\n\n // On initial connection error in auto mode, fallback to streaming\n if (!isRetry && configuredTransport === 'auto' && !ready) {\n switchToStreaming()\n }\n }\n\n ws.onclose = function (event) {\n if (fallbackTimer) clearTimeout(fallbackTimer)\n console.warn('socket disconnect:', event)\n __socket = false\n ready = false\n\n // Only notify disconnected if we're on websocket transport\n if (currentTransport === 'websocket') {\n notifyConnectionChange(ConnectionState.Disconnected)\n setTimeout(() => reconnect && connectSocket(), 500)\n }\n }\n}\n\n/**\n * Find all L-tagged (binary link) properties in data\n * Returns array of { path, hash }\n */\nfunction findLinkedResources(obj, path = '') {\n const resources = []\n\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return resources\n }\n\n if (Array.isArray(obj)) {\n for (let i = 0; i < obj.length; i++) {\n resources.push(...findLinkedResources(obj[i], path ? `${path}.${i}` : String(i)))\n }\n return resources\n }\n\n for (const key of Object.keys(obj)) {\n // Check for L-tag in key (from JJS encoding: key<!L>)\n if (key.endsWith('<!L>')) {\n const cleanKey = key.slice(0, -4)\n const hash = obj[key]\n resources.push({\n path: path ? `${path}.${cleanKey}` : cleanKey,\n hash,\n originalKey: key\n })\n } else {\n resources.push(...findLinkedResources(obj[key], path ? `${path}.${key}` : key))\n }\n }\n\n return resources\n}\n\n/**\n * Find all F-tagged (shared file) properties in data\n * Returns array of { path, hash, originalKey }\n */\nfunction findFileTags(obj, path = '') {\n const files = []\n\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return files\n }\n\n if (Array.isArray(obj)) {\n for (let i = 0; i < obj.length; i++) {\n files.push(...findFileTags(obj[i], path ? `${path}.${i}` : String(i)))\n }\n return files\n }\n\n for (const key of Object.keys(obj)) {\n // Check for F-tag in key (client-to-client shared file marker)\n if (key.endsWith('<!F>')) {\n const cleanKey = key.slice(0, -4)\n const hash = obj[key]\n files.push({\n path: path ? `${path}.${cleanKey}` : cleanKey,\n hash,\n originalKey: key\n })\n } else {\n files.push(...findFileTags(obj[key], path ? `${path}.${key}` : key))\n }\n }\n\n return files\n}\n\n/**\n * Clean up F-tagged keys (rename key<!F> to key)\n */\nfunction cleanFileTags(obj) {\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return obj\n }\n\n if (Array.isArray(obj)) {\n return obj.map(cleanFileTags)\n }\n\n const cleaned = {}\n for (const key of Object.keys(obj)) {\n if (key.endsWith('<!F>')) {\n const cleanKey = key.slice(0, -4)\n cleaned[cleanKey] = obj[key]\n } else {\n cleaned[key] = cleanFileTags(obj[key])\n }\n }\n return cleaned\n}\n\n/**\n * Fetch shared files (client-to-client transfers)\n * Retries if upload is still in progress\n */\nasync function fetchSharedFiles(data, maxRetries = 5) {\n const files = findFileTags(data)\n\n if (files.length === 0) {\n return data\n }\n\n console.log(`\uD83E\uDD8D Fetching ${files.length} shared file(s)`)\n\n const cleanedData = cleanFileTags(data)\n\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n await Promise.all(files.map(async ({ path, hash }) => {\n let retries = 0\n let backoff = 100 // Start with 100ms\n\n while (retries < maxRetries) {\n try {\n const response = await fetch(`${baseUrl}/api/ape/data/${hash}`, {\n credentials: 'include'\n })\n\n if (!response.ok) {\n // 404 might mean file not uploaded yet, retry\n if (response.status === 404 && retries < maxRetries - 1) {\n retries++\n await new Promise(r => setTimeout(r, backoff))\n backoff *= 2 // Exponential backoff\n continue\n }\n throw new Error(`Failed to fetch shared file: ${response.status}`)\n }\n\n const arrayBuffer = await response.arrayBuffer()\n setValueAtPath(cleanedData, path, arrayBuffer)\n\n // Check if upload is still in progress\n const isComplete = response.headers.get('X-Ape-Complete') === '1'\n if (!isComplete) {\n console.log(`\uD83E\uDD8D Shared file ${hash} still uploading (${response.headers.get('X-Ape-Total-Received') || '?'} bytes)`)\n }\n break\n } catch (err) {\n if (retries >= maxRetries - 1) {\n console.error(`\uD83E\uDD8D Failed to fetch shared file at ${path}:`, err)\n setValueAtPath(cleanedData, path, null)\n }\n retries++\n await new Promise(r => setTimeout(r, backoff))\n backoff *= 2\n }\n }\n }))\n\n return cleanedData\n}\n\n/**\n * Set a value at a nested path in an object\n */\nfunction setValueAtPath(obj, path, value) {\n const parts = path.split('.')\n let current = obj\n\n for (let i = 0; i < parts.length - 1; i++) {\n current = current[parts[i]]\n }\n\n current[parts[parts.length - 1]] = value\n}\n\n/**\n * Clean up L-tagged keys (rename key<!L> to key)\n */\nfunction cleanLinkedKeys(obj) {\n if (obj === null || obj === undefined || typeof obj !== 'object') {\n return obj\n }\n\n if (Array.isArray(obj)) {\n return obj.map(cleanLinkedKeys)\n }\n\n const cleaned = {}\n for (const key of Object.keys(obj)) {\n if (key.endsWith('<!L>')) {\n const cleanKey = key.slice(0, -4)\n cleaned[cleanKey] = obj[key]\n } else {\n cleaned[key] = cleanLinkedKeys(obj[key])\n }\n }\n return cleaned\n}\n\n/**\n * Fetch binary resources and hydrate data object\n */\nasync function fetchLinkedResources(data, clientId) {\n const resources = findLinkedResources(data)\n\n if (resources.length === 0) {\n return data\n }\n\n console.log(`\uD83E\uDD8D Fetching ${resources.length} binary resource(s)`)\n\n const cleanedData = cleanLinkedKeys(data)\n\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n await Promise.all(resources.map(async ({ path, hash }) => {\n try {\n const response = await fetch(`${baseUrl}/api/ape/data/${hash}`, {\n credentials: 'include',\n headers: {\n 'X-Ape-Client-Id': clientId || ''\n }\n })\n\n if (!response.ok) {\n throw new Error(`Failed to fetch binary resource: ${response.status}`)\n }\n\n const arrayBuffer = await response.arrayBuffer()\n setValueAtPath(cleanedData, path, arrayBuffer)\n } catch (err) {\n console.error(`\uD83E\uDD8D Failed to fetch binary resource at ${path}:`, err)\n setValueAtPath(cleanedData, path, null)\n }\n }))\n\n return cleanedData\n}\n\n/**\n * Attempt to establish connection with network pre-checks\n */\nasync function attemptConnection() {\n // Check if browser is online\n if (typeof navigator !== 'undefined' && !navigator.onLine) {\n notifyConnectionChange(ConnectionState.Offline)\n return\n }\n\n // Perform captive portal check\n notifyConnectionChange(ConnectionState.Connecting)\n const pingResult = await checkCaptivePortal()\n\n if (pingResult === 'walled') {\n notifyConnectionChange(ConnectionState.Walled)\n // Retry network check periodically\n scheduleNetworkRetry()\n return\n }\n\n // Network is good, proceed with socket connection\n proceedWithConnection()\n}\n\n/**\n * Schedule a retry of network check (for walled/offline states)\n */\nfunction scheduleNetworkRetry() {\n if (networkCheckTimer) return\n networkCheckTimer = setTimeout(() => {\n networkCheckTimer = null\n attemptConnection()\n }, WS_RETRY_INTERVAL)\n}\n\n/**\n * Proceed with WebSocket/polling connection after network checks pass\n */\nfunction proceedWithConnection() {\n // Determine which transport to use\n if (configuredTransport === 'polling') {\n switchToStreaming()\n } else {\n // 'auto' or 'websocket' - try WebSocket first\n tryWebSocket(false)\n }\n}\n\nfunction connectSocket() {\n // Skip if already connected or connecting\n if (__socket && __socket.readyState !== WebSocket.CLOSED) {\n return buildClientInterface()\n }\n if (currentTransport === 'polling' && streamingTransport?.isConnected()) {\n return buildClientInterface()\n }\n if (connectionState === ConnectionState.Connecting) {\n return buildClientInterface()\n }\n\n // Start connection with network pre-checks\n attemptConnection()\n\n return buildClientInterface()\n}\n\n/**\n * Check if value is binary data (ArrayBuffer, typed array, or Blob)\n */\nfunction isBinaryData(value) {\n if (value === null || value === undefined) return false\n return value instanceof ArrayBuffer ||\n ArrayBuffer.isView(value) ||\n (typeof Blob !== 'undefined' && value instanceof Blob)\n}\n\n/**\n * Get binary type tag (A for ArrayBuffer, B for Blob)\n */\nfunction getBinaryTag(value) {\n if (typeof Blob !== 'undefined' && value instanceof Blob) return 'B'\n return 'A'\n}\n\n/**\n * Generate a simple hash for binary upload\n */\nfunction generateUploadHash(path) {\n let hash = 0\n for (let i = 0; i < path.length; i++) {\n const char = path.charCodeAt(i)\n hash = ((hash << 5) - hash) + char\n hash = hash & hash\n }\n return Math.abs(hash).toString(36)\n}\n\n/**\n * Find and extract binary data from payload\n * Returns { processedData, uploads: [{ path, hash, data, tag }] }\n */\nfunction processBinaryForUpload(data, path = '') {\n if (data === null || data === undefined) {\n return { processedData: data, uploads: [] }\n }\n\n if (isBinaryData(data)) {\n const tag = getBinaryTag(data)\n const hash = generateUploadHash(path || 'root')\n return {\n processedData: { [`__ape_upload__`]: hash },\n uploads: [{ path, hash, data, tag }]\n }\n }\n\n if (Array.isArray(data)) {\n const processedArray = []\n const allUploads = []\n\n for (let i = 0; i < data.length; i++) {\n const itemPath = path ? `${path}.${i}` : String(i)\n const { processedData, uploads } = processBinaryForUpload(data[i], itemPath)\n processedArray.push(processedData)\n allUploads.push(...uploads)\n }\n\n return { processedData: processedArray, uploads: allUploads }\n }\n\n if (typeof data === 'object') {\n const processedObj = {}\n const allUploads = []\n\n for (const key of Object.keys(data)) {\n const itemPath = path ? `${path}.${key}` : key\n const { processedData, uploads } = processBinaryForUpload(data[key], itemPath)\n\n // If this was binary data, mark the key with <!B> or <!A> tag\n if (uploads.length > 0 && processedData?.__ape_upload__) {\n const tag = uploads[uploads.length - 1].tag\n processedObj[`${key}<!${tag}>`] = processedData.__ape_upload__\n } else {\n processedObj[key] = processedData\n }\n allUploads.push(...uploads)\n }\n\n return { processedData: processedObj, uploads: allUploads }\n }\n\n return { processedData: data, uploads: [] }\n}\n\n/**\n * Find and extract binary data for SHARING (client-to-client)\n * Uses <!F> tag instead of <!A>/<!B>\n * Returns { processedData, shares: [{ path, hash, data }] }\n */\nfunction processBinaryForSharing(data, path = '') {\n if (data === null || data === undefined) {\n return { processedData: data, shares: [] }\n }\n\n if (isBinaryData(data)) {\n const hash = generateUploadHash(path || 'share')\n return {\n processedData: { [`__ape_share__`]: hash },\n shares: [{ path, hash, data }]\n }\n }\n\n if (Array.isArray(data)) {\n const processedArray = []\n const allShares = []\n\n for (let i = 0; i < data.length; i++) {\n const itemPath = path ? `${path}.${i}` : String(i)\n const { processedData, shares } = processBinaryForSharing(data[i], itemPath)\n processedArray.push(processedData)\n allShares.push(...shares)\n }\n\n return { processedData: processedArray, shares: allShares }\n }\n\n if (typeof data === 'object') {\n const processedObj = {}\n const allShares = []\n\n for (const key of Object.keys(data)) {\n const itemPath = path ? `${path}.${key}` : key\n const { processedData, shares } = processBinaryForSharing(data[key], itemPath)\n\n // If this was binary data, mark the key with <!F> tag\n if (shares.length > 0 && processedData?.__ape_share__) {\n processedObj[`${key}<!F>`] = processedData.__ape_share__\n } else {\n processedObj[key] = processedData\n }\n allShares.push(...shares)\n }\n\n return { processedData: processedObj, shares: allShares }\n }\n\n return { processedData: data, shares: [] }\n}\n\n/**\n * Upload shared files via HTTP PUT\n * Uses different endpoint pattern for streaming files\n */\nasync function uploadSharedFiles(shares) {\n if (shares.length === 0) return\n\n // Build base URL\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n console.log(`\uD83E\uDD8D Uploading ${shares.length} shared file(s)`)\n\n await Promise.all(shares.map(async ({ hash, data }) => {\n try {\n // For shared files, use upload pattern with hash as both queryId and pathHash\n const response = await fetch(`${baseUrl}/api/ape/data/_share/${hash}`, {\n method: 'PUT',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/octet-stream'\n },\n body: data\n })\n\n if (!response.ok) {\n throw new Error(`Shared upload failed: ${response.status}`)\n }\n } catch (err) {\n console.error(`\uD83E\uDD8D Failed to upload shared file ${hash}:`, err)\n throw err\n }\n }))\n}\n\n/**\n * Upload binary data via HTTP PUT\n */\nasync function uploadBinaryData(queryId, uploads) {\n if (uploads.length === 0) return\n\n // Build base URL\n const hostname = window.location.hostname\n const isLocal = [\"localhost\", \"127.0.0.1\", \"[::1]\"].includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n const baseUrl = `${protocol}://${hostname}${portSuffix}`\n\n console.log(`\uD83E\uDD8D Uploading ${uploads.length} binary file(s)`)\n\n await Promise.all(uploads.map(async ({ hash, data }) => {\n try {\n const response = await fetch(`${baseUrl}/api/ape/data/${queryId}/${hash}`, {\n method: 'PUT',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/octet-stream'\n },\n body: data\n })\n\n if (!response.ok) {\n throw new Error(`Upload failed: ${response.status}`)\n }\n } catch (err) {\n console.error(`\uD83E\uDD8D Failed to upload binary at ${hash}:`, err)\n throw err\n }\n }))\n}\n\nwsSend = function (type, data, createdAt, dirctCall) {\n let rej, promiseIsLive = false;\n const timeLetForReqToBeMade = (createdAt + totalRequestTimeout) - Date.now()\n\n const timer = setTimeout(() => {\n if (promiseIsLive) {\n rej(new Error(\"Request Timedout for :\" + type))\n }\n }, timeLetForReqToBeMade);\n\n // Process binary data for upload\n const { processedData, uploads } = processBinaryForUpload(data)\n\n const payload = {\n type,\n data: processedData,\n //referer:window.location.href,\n createdAt: new Date(createdAt),\n requestedAt: dirctCall ? undefined\n : new Date()\n }\n const message = jss.stringify(payload)\n const queryId = messageHash(message);\n\n const replyPromise = new Promise((resolve, reject) => {\n rej = reject\n waitingOn[queryId] = (err, result) => {\n clearTimeout(timer)\n replyPromise.then = next.bind(replyPromise)\n if (err) {\n reject(err)\n } else {\n resolve(result)\n }\n }\n __socket.send(message);\n\n // Upload binary data after sending WS message\n if (uploads.length > 0) {\n uploadBinaryData(queryId, uploads).catch(err => {\n console.error('\uD83E\uDD8D Binary upload failed:', err)\n // The server will timeout waiting for the upload\n })\n }\n });\n const next = replyPromise.then;\n replyPromise.then = worker => {\n promiseIsLive = true;\n replyPromise.then = next.bind(replyPromise)\n replyPromise.catch = err.bind(replyPromise)\n return next.call(replyPromise, worker)\n }\n const err = replyPromise.catch;\n replyPromise.catch = worker => {\n promiseIsLive = true;\n replyPromise.catch = err.bind(replyPromise)\n replyPromise.then = next.bind(replyPromise)\n return err.call(replyPromise, worker)\n }\n return replyPromise\n} // END wsSend\n\n\nconst sender = (type, data) => {\n if (\"string\" !== typeof type) {\n throw new Error(\"Missing Path vaule\")\n }\n\n const createdAt = Date.now()\n\n if (ready) {\n return wsSend(type, data, createdAt, true)\n }\n\n const timeLetForReqToBeMade = (createdAt + connectTimeout) - Date.now() // 5sec for reconnect\n\n const timer = setTimeout(() => {\n const errMessage = \"Request not sent for :\" + type\n if (payload.waiting) {\n payload.reject(new Error(errMessage))\n } else {\n throw new Error(errMessage)\n }\n }, timeLetForReqToBeMade);\n\n const payload = { type, data, resolve: undefined, reject: undefined, waiting: false, createdAt, timer };\n const waitingOnOpen = new Promise((res, rej) => { payload.resolve = res; payload.reject = rej; })\n\n const waitingOnOpenThen = waitingOnOpen.then;\n const waitingOnOpenCatch = waitingOnOpen.catch;\n waitingOnOpen.then = worker => {\n payload.waiting = true;\n waitingOnOpen.then = waitingOnOpenThen.bind(waitingOnOpen)\n waitingOnOpen.catch = waitingOnOpenCatch.bind(waitingOnOpen)\n return waitingOnOpenThen.call(waitingOnOpen, worker)\n }\n waitingOnOpen.catch = worker => {\n payload.waiting = true;\n waitingOnOpen.catch = waitingOnOpenCatch.bind(waitingOnOpen)\n waitingOnOpen.then = waitingOnOpenThen.bind(waitingOnOpen)\n return waitingOnOpenCatch.call(waitingOnOpen, worker)\n }\n\n aWaitingSend.push(payload)\n if (!__socket) {\n connectSocket()\n }\n\n return waitingOnOpen\n} // END sender\n\n/**\n * Build the client interface object\n */\nfunction buildClientInterface() {\n return {\n sender: wrap(sender),\n setOnReceiver: (onTypeStFn, handlerFn) => {\n if (\"string\" === typeof onTypeStFn) {\n // Replace handler for this type (prevents duplicates in React StrictMode)\n ofTypesOb[onTypeStFn] = [handlerFn]\n } else {\n // For general receivers, prevent duplicates by checking\n if (!receiverArray.includes(onTypeStFn)) {\n receiverArray.push(onTypeStFn)\n }\n }\n },\n onConnectionChange: (handler) => {\n connectionChangeListeners.push(handler)\n // Immediately call with current state\n handler(connectionState)\n // Return unsubscribe function\n return () => {\n const idx = connectionChangeListeners.indexOf(handler)\n if (idx > -1) connectionChangeListeners.splice(idx, 1)\n }\n },\n // Expose current transport type (read-only)\n get transport() { return currentTransport }\n }\n}\n\nconnectSocket.autoReconnect = () => reconnect = true\nconnectSocket.ConnectionState = ConnectionState\nconnect = connectSocket\n\nexport default connect;\nexport { ConnectionState };\n", "import jss from '../../utils/jss'\n\n/**\n * HTTP Streaming transport - fallback when WebSocket is blocked\n * Uses fetch + ReadableStream for receiving, POST for sending\n */\n\n/**\n * Get base URL for polling endpoints\n */\nfunction getPollUrl() {\n const hostname = window.location.hostname\n const localServers = [\"localhost\", \"127.0.0.1\", \"[::1]\"]\n const isLocal = localServers.includes(hostname)\n const isHttps = window.location.protocol === \"https:\"\n\n const port = isLocal ? 9010 : (window.location.port || (isHttps ? 443 : 80))\n\n const protocol = isHttps ? \"https\" : \"http\"\n const portSuffix = (isLocal || (port !== 80 && port !== 443)) ? `:${port}` : \"\"\n\n return `${protocol}://${hostname}${portSuffix}/api/ape/poll`\n}\n\n/**\n * Parse JSON objects from a streaming buffer by counting braces\n * Handles strings containing braces correctly\n */\nfunction parseStreamBuffer(buffer) {\n const messages = []\n let start = -1\n let depth = 0\n let inString = false\n let escaped = false\n\n for (let i = 0; i < buffer.length; i++) {\n const char = buffer[i]\n\n if (escaped) {\n escaped = false\n continue\n }\n\n if (char === '\\\\' && inString) {\n escaped = true\n continue\n }\n\n if (char === '\"') {\n inString = !inString\n continue\n }\n\n if (inString) continue\n\n if (char === '{') {\n if (depth === 0) {\n start = i\n }\n depth++\n } else if (char === '}') {\n depth--\n if (depth === 0 && start !== -1) {\n const jsonStr = buffer.slice(start, i + 1)\n try {\n messages.push(jss.parse(jsonStr))\n } catch (e) {\n console.error('\uD83E\uDD8D Failed to parse stream message:', e)\n }\n start = -1\n }\n }\n }\n\n // Return remaining buffer (incomplete message)\n const remaining = start !== -1 ? buffer.slice(start) : ''\n return { messages, remaining }\n}\n\n/**\n * Create streaming transport instance\n */\nfunction createStreamingTransport() {\n let isActive = false\n let abortController = null\n let streamBuffer = ''\n let reconnectTimer = null\n\n // Callbacks\n let onMessage = () => { }\n let onOpen = () => { }\n let onClose = () => { }\n let onError = () => { }\n\n /**\n * Start the streaming connection\n */\n async function connect() {\n if (isActive) return\n\n isActive = true\n abortController = new AbortController()\n\n try {\n const response = await fetch(getPollUrl(), {\n method: 'GET',\n credentials: 'include',\n signal: abortController.signal,\n headers: {\n 'Accept': 'application/json'\n }\n })\n\n if (!response.ok) {\n throw new Error(`Stream connect failed: ${response.status}`)\n }\n\n onOpen()\n\n const reader = response.body.getReader()\n const decoder = new TextDecoder()\n\n async function read() {\n while (isActive) {\n try {\n const { done, value } = await reader.read()\n\n if (done) {\n // Stream ended - reconnect\n scheduleReconnect()\n return\n }\n\n streamBuffer += decoder.decode(value, { stream: true })\n const { messages, remaining } = parseStreamBuffer(streamBuffer)\n streamBuffer = remaining\n\n for (const msg of messages) {\n // Skip heartbeat messages\n if (msg.type === '__heartbeat__') continue\n onMessage(msg)\n }\n } catch (readErr) {\n if (readErr.name === 'AbortError') return\n console.error('\uD83E\uDD8D Stream read error:', readErr)\n scheduleReconnect()\n return\n }\n }\n }\n\n read()\n\n } catch (err) {\n if (err.name === 'AbortError') return\n\n console.error('\uD83E\uDD8D Stream connection error:', err)\n onError(err)\n scheduleReconnect()\n }\n }\n\n /**\n * Schedule reconnection with small delay\n */\n function scheduleReconnect() {\n if (!isActive) return\n\n if (reconnectTimer) {\n clearTimeout(reconnectTimer)\n }\n\n reconnectTimer = setTimeout(() => {\n if (isActive) {\n connect()\n }\n }, 500)\n }\n\n /**\n * Send a message via POST\n */\n async function send(type, data, createdAt) {\n const payload = {\n type,\n data,\n createdAt: new Date(createdAt)\n }\n\n const response = await fetch(getPollUrl(), {\n method: 'POST',\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: jss.stringify(payload)\n })\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({ error: 'Unknown error' }))\n throw new Error(error.error || `Request failed: ${response.status}`)\n }\n\n const result = jss.parse(await response.text())\n return result.data\n }\n\n /**\n * Close the streaming connection\n */\n function close() {\n isActive = false\n\n if (reconnectTimer) {\n clearTimeout(reconnectTimer)\n reconnectTimer = null\n }\n\n if (abortController) {\n abortController.abort()\n abortController = null\n }\n\n streamBuffer = ''\n onClose()\n }\n\n return {\n connect,\n send,\n close,\n isConnected: () => isActive,\n set onMessage(fn) { onMessage = fn },\n set onOpen(fn) { onOpen = fn },\n set onClose(fn) { onClose = fn },\n set onError(fn) { onError = fn }\n }\n}\n\nexport { createStreamingTransport, getPollUrl }\n", "import connectSocket from './connectSocket.js'\n\nconst client = connectSocket()\nconnectSocket.autoReconnect()\n\n// Global API - use defineProperty to bypass Proxy interception\nwindow.api = client.sender\nObject.defineProperty(window.api, 'on', {\n value: client.setOnReceiver,\n writable: false,\n enumerable: false,\n configurable: false\n})\nObject.defineProperty(window.api, 'onConnectionChange', {\n value: client.onConnectionChange,\n writable: false,\n enumerable: false,\n configurable: false\n})\n// Read-only transport property - only ape can change this internally\nObject.defineProperty(window.api, 'transport', {\n get: () => client.transport,\n enumerable: false,\n configurable: false\n})\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["require_messageHash", "__commonJSMin", "exports", "module", "alphabet", "toBase32", "n", "remainder", "current", "jenkinsOneAtATimeHash", "keyString", "hash", "charIndex", "messageHash", "messageSt", "require_jss", "__commonJSMin", "exports", "module", "encode", "obj", "tagLookup", "visited", "encodeValue", "value", "path", "type", "tag", "visitedEncode", "isArray", "keys", "result", "typesFound", "i", "key", "t", "v", "encodeValueWithVisited", "objKeys", "stringify", "parse", "encoded", "decode", "data", "pointers2Res", "s", "n", "sourceToPointAt", "replaceAtThisPlace", "name", "message", "stack", "err", "a", "o", "decodeValue", "val", "currentPath", "typeTags", "res", "itemPath", "decodedValue", "nam", "parseKeyWithTags", "match", "multiMatch", "arrayMatch", "changeAttributeReference", "refPath", "attrPath", "refKeys", "attrKeys", "ref", "attr", "import_messageHash", "import_jss", "import_jss", "getPollUrl", "hostname", "isLocal", "isHttps", "port", "protocol", "portSuffix", "parseStreamBuffer", "buffer", "messages", "start", "depth", "inString", "escaped", "i", "char", "jsonStr", "jss", "e", "remaining", "createStreamingTransport", "isActive", "abortController", "streamBuffer", "reconnectTimer", "onMessage", "onOpen", "onClose", "onError", "connect", "response", "reader", "decoder", "read", "done", "value", "scheduleReconnect", "msg", "readErr", "err", "send", "type", "data", "createdAt", "payload", "error", "close", "fn", "connect", "ConnectionState", "connectionState", "connectionChangeListeners", "notifyConnectionChange", "newState", "fn", "configuredTransport", "currentTransport", "streamingTransport", "wsRetryTimer", "networkCheckTimer", "WS_FALLBACK_TIMEOUT", "WS_RETRY_INTERVAL", "PING_TIMEOUT", "MAX_PING_CLOCK_SKEW", "isDevMode", "getPingUrl", "hostname", "isHttps", "port", "protocol", "portSuffix", "checkCaptivePortal", "controller", "timeoutId", "response", "data", "now", "skew", "err", "setupOnlineListeners", "attemptConnection", "getSocketUrl", "isLocal", "reconnect", "connectTimeout", "totalRequestTimeout", "joinKey", "reservedKeys", "handler", "key", "wrapperFn", "a", "b", "path", "body", "wrap", "api", "__socket", "ready", "wsSend", "waitingOn", "aWaitingSend", "receiverArray", "ofTypesOb", "switchToStreaming", "createStreamingTransport", "msg", "type", "processedData", "fetchLinkedResources", "fetchSharedFiles", "fetchErr", "worker", "resolve", "reject", "waiting", "createdAt", "timer", "resultPromise", "streamingSend", "startWsRetry", "tryWebSocket", "isRetry", "ws", "fallbackTimer", "event", "queryId", "jss", "hydratedData", "connectSocket", "findLinkedResources", "obj", "resources", "i", "cleanKey", "hash", "findFileTags", "files", "cleanFileTags", "cleaned", "maxRetries", "cleanedData", "baseUrl", "retries", "backoff", "r", "arrayBuffer", "setValueAtPath", "value", "parts", "current", "cleanLinkedKeys", "clientId", "scheduleNetworkRetry", "proceedWithConnection", "buildClientInterface", "isBinaryData", "getBinaryTag", "generateUploadHash", "char", "processBinaryForUpload", "tag", "processedArray", "allUploads", "itemPath", "uploads", "processedObj", "uploadBinaryData", "queryId", "uploads", "hostname", "isLocal", "isHttps", "port", "protocol", "portSuffix", "baseUrl", "hash", "data", "response", "err", "wsSend", "type", "createdAt", "dirctCall", "rej", "promiseIsLive", "timeLetForReqToBeMade", "totalRequestTimeout", "timer", "processedData", "processBinaryForUpload", "payload", "message", "jss", "messageHash", "replyPromise", "resolve", "reject", "waitingOn", "result", "next", "__socket", "worker", "sender", "ready", "connectTimeout", "errMessage", "waitingOnOpen", "res", "waitingOnOpenThen", "waitingOnOpenCatch", "aWaitingSend", "connectSocket", "buildClientInterface", "wrap", "onTypeStFn", "handlerFn", "ofTypesOb", "receiverArray", "handler", "connectionChangeListeners", "connectionState", "idx", "currentTransport", "reconnect", "ConnectionState", "connect", "connectSocket_default", "client", "connectSocket_default"]
|
|
7
7
|
}
|