@urun-sh/core 0.1.41 → 0.1.42

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- import{a as ne,b as j,f as re,i as B}from"./chunk-4O3YOYT6.mjs";import"./chunk-FNR7JDXN.mjs";var _e="session-api.prod.cloud.urun.sh",ye=["https://session-api.use2.prod.cloud.urun.sh","https://session-api.usw2.prod.cloud.urun.sh"];function $(n){return n.trim().replace(/\/+$/,"")}function se(n,e){let t=[],r=s=>{if(!s)return;let o=$(s);o&&!t.includes(o)&&t.push(o)};r(n);for(let s of e??[])r(s);for(let s of Ee(n))r(s);return t}var Se=120,ve=1e3,be=3;function ke(n){if(!n)return null;try{let e=new URL(n),t=e.pathname.replace(/\/api\/sessions\/create\/?$/,"");return $(`${e.origin}${t}`)}catch{return null}}async function oe(n){let e=se(n.baseUrl,n.fallbackUrls),t=null,r=e.length>1;for(let s of e)try{return await Re(s,n,{pollAttempts:Se,retryAfterLimitMs:r?ve:void 0})}catch(o){if(t=o instanceof Error?o:new Error(String(o)),t instanceof A)throw t}throw t??new Error("[urun] session allocation failed")}async function Re(n,e,t){let r,s,o,i=n,u=0,h=new Set;for(let p=0;p<t.pollAttempts;p++){s=o??await W(e),o=void 0;let d=r?await fetch(`${i}/api/session-requests/${encodeURIComponent(r)}`,{headers:K(e,s)}):await fetch(`${i}/api/sessions/create`,{method:"POST",redirect:"manual",headers:{...K(e,s),"Content-Type":"application/json","Idempotency-Key":e.idempotencyKey},body:JSON.stringify(Ae(e))});if(!r&&(d.status===307||d.status===308)){let f=ke(d.headers.get("location"));if(f&&f!==i&&u<be){u+=1,i=f;continue}throw new Error(`[urun] session create redirected from ${i} without a usable target`)}let a=await ae(d);if(d.ok&&(a.status==="allocated"||!a.status&&!!a.session_id)&&!!a.session_id){let f=a.session_id;if(!a.ws_url)throw new A(`[urun] gateway allocated session ${f} without ws_url`);if(!ce(a.ws_url))throw new A(`[urun] gateway allocated session ${f} with non-absolute ws_url`);return{baseUrl:i,sessionId:f,wsUrl:a.ws_url,response:a}}if(d.status===202||a.status==="pending"||a.status==="queued"||a.queued){if(r=a.request_id||r,!r)throw new Error("[urun] gateway queued session without request_id");await Te(Ie(d,a,t.retryAfterLimitMs));continue}if((d.status===401||d.status===403)&&e.getAccessToken){let f=s??"";h.add(f);let w=await W(e,{forceRefresh:!0,reason:"unauthorized"});if(w&&!h.has(w)){o=w,r=void 0;continue}}let g=a.error_message||a.error_code||`HTTP ${d.status}`;throw new Error(`[urun] session allocation failed at ${i}: ${g}`)}throw new Error(`[urun] timed out waiting for session allocation at ${i}`)}function K(n,e){let t={"X-Tenant-Id":n.orgId,"X-Auth-Provider":n.authProvider||"default","X-User-Id":"anonymous"};return e&&(t.Authorization=`Bearer ${e}`),t}async function W(n,e){return n.getAccessToken?await n.getAccessToken(e)??void 0:n.jwt}function Ae(n){return{app:n.app,function:n.functionName,gpus:1,idempotency_key:n.idempotencyKey}}async function ie(n){let e=se(n.baseUrl,n.fallbackUrls),t=null;for(let r of e)try{let s={baseUrl:r,app:"",functionName:"",orgId:n.orgId,jwt:n.jwt,getAccessToken:n.getAccessToken,authProvider:n.authProvider,idempotencyKey:""},o=await W(s),i=await fetch(`${$(r)}/api/sessions/${encodeURIComponent(n.sessionId)}/viewer-connect`,{headers:K(s,o)});if(!i.ok)throw new Error(`[urun] viewer-connect for ${n.sessionId} failed: HTTP ${i.status}`);let u=await ae(i);if(!u.ws_url||!ce(u.ws_url))throw new A(`[urun] viewer-connect returned no usable ws_url for ${n.sessionId}`);return{baseUrl:$(r),sessionId:n.sessionId,wsUrl:u.ws_url,response:u}}catch(s){if(t=s instanceof Error?s:new Error(String(s)),t instanceof A)throw t}throw t??new Error("[urun] viewer-connect failed")}async function ae(n){try{let e=await n.json();return e&&typeof e=="object"?e:{}}catch{return{}}}function Ie(n,e,t){let r=Number(n.headers.get("Retry-After")||""),s=Number(e.retry_after_seconds??r),o=t??1e4;return Number.isFinite(s)&&s>0?Math.min(s*1e3,o):1e3}function Te(n){return new Promise(e=>setTimeout(e,n))}var A=class extends Error{};function ce(n){try{let e=new URL(n);return e.protocol==="ws:"||e.protocol==="wss:"}catch{return!1}}function Ee(n){try{return new URL(n).hostname!==_e?[]:ye}catch{return[]}}import*as P from"yjs";var ue=Symbol("urun:doc:remote"),Pe=Symbol("urun:doc:local");function I(n){return n!==null&&typeof n=="object"&&!Array.isArray(n)}var N="$bytes";function xe(n){return n instanceof Uint8Array||n instanceof ArrayBuffer}function Oe(n){if(!I(n))return!1;let e=Object.keys(n);return e.length===1&&e[0]===N&&typeof n[N]=="string"}function Ue(n){return n instanceof ArrayBuffer?new Uint8Array(n):n}function Ce(n){if(typeof Buffer<"u")return Buffer.from(n).toString("base64");let e="";for(let t=0;t<n.length;t++)e+=String.fromCharCode(n[t]);return btoa(e)}function Me(n){if(typeof Buffer<"u")return new Uint8Array(Buffer.from(n,"base64"));let e=atob(n),t=new Uint8Array(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}function Y(n){if(xe(n))return{[N]:Ce(Ue(n))};if(Array.isArray(n))return n.map(Y);if(I(n)){let e={};for(let[t,r]of Object.entries(n))e[t]=Y(r);return e}return n}function x(n){if(Oe(n))return Me(n[N]);if(Array.isArray(n))return n.map(x);if(I(n)){let e={};for(let[t,r]of Object.entries(n))e[t]=x(r);return e}return n}function J(n,e){let t={...n};for(let r of Object.keys(e)){let s=e[r],o=t[r];I(s)&&I(o)?t[r]=J(o,s):t[r]=s}return t}var de=Symbol("urun:doc:path-absent");function qe(n,e){let t=e.split("."),r=n;for(let s of t){if(r===null||typeof r!="object"||!(s in r))return de;r=r[s]}return r}function le(n){return n===void 0?n:JSON.parse(JSON.stringify(n))}var F=class{_doc=new P.Doc;_root=this._doc.getMap("session");_listeners=new Set;_key;_sessionId;_transport;_transportUnsubs=[];_synced;_pendingPatches=[];_syncWaiters=new Set;_texts=new Map;_observer=()=>this.notify();_updateHandler=(e,t)=>{t!==ue&&this._transport?.sendDocSync(this._key,e)};constructor(e,t,r){this._key=e,this._sessionId=t,this._transport=r??null,this._synced=this._transport===null,this._root.observeDeep(this._observer),this._doc.on("update",this._updateHandler),this._transport&&(this._transportUnsubs.push(this._transport.onDocSync(this._key,s=>this.applyRemote(s)),this._transport.onDocSyncReady(()=>this.sendHello())),this._transport.isOpen&&this.sendHello())}setSessionId(e){this._sessionId=e}get synced(){return this._synced}onSynced(e){return this._synced?(e(),()=>{}):(this._syncWaiters.add(e),()=>this._syncWaiters.delete(e))}set(e){if(e=Y(e),!this._synced){this._pendingPatches.push(le(e)),this.notify();return}this.applyPatch(e)}get(e,t){let r=this.snapshot();if(!e)return x(r);let s=qe(r,e);return s===de?t:x(s)}on(e,t){return this._listeners.add(t),()=>this._listeners.delete(t)}text(e){let t=this._texts.get(e);return t||(t=new H(this._doc.getText(`text:${e}`)),this._texts.set(e,t)),t}dispose(){this._root.unobserveDeep(this._observer),this._doc.off("update",this._updateHandler);for(let e of this._transportUnsubs)e();this._transportUnsubs=[],this._transport=null,this._listeners.clear(),this._syncWaiters.clear();for(let e of this._texts.values())e.dispose();this._texts.clear(),this._doc.destroy()}sendHello(){this._transport&&this._transport.sendDocSync(this._key,P.encodeStateAsUpdate(this._doc))}applyRemote(e){if(P.applyUpdate(this._doc,e,ue),!this._synced){this._synced=!0;let t=this._pendingPatches.splice(0);for(let s of t)this.applyPatch(s);let r=[...this._syncWaiters];this._syncWaiters.clear();for(let s of r)s()}}applyPatch(e){this._doc.transact(()=>{let t=this._root.toJSON();for(let[r,s]of Object.entries(e)){let o=t[r],i=I(s)&&I(o)?J(o,s):le(s);JSON.stringify(i)!==JSON.stringify(o)&&this._root.set(r,i)}},Pe)}snapshot(){let e=this._root.toJSON();for(let t of this._pendingPatches)e=J(e,t);return e}notify(){let e=x(this.snapshot());for(let t of this._listeners)t(e)}},H=class{constructor(e){this._ytext=e;this._observer=t=>{for(let r of t.delta)if(typeof r.insert=="string"&&r.insert.length>0){let s=r.insert;for(let o of this._delta)o(s)}},this._ytext.observe(this._observer)}_ytext;_delta=new Set;_observer;append(e){e.length!==0&&this._ytext.insert(this._ytext.length,e)}toString(){return this._ytext.toString()}get length(){return this._ytext.length}on(e,t){return this._delta.add(t),()=>this._delta.delete(t)}dispose(){this._ytext.unobserve(this._observer),this._delta.clear()}};var y=class extends Error{requestId;code;constructor(e,t){super(e),this.name="RequestError",this.requestId=t?.requestId,this.code=t?.code,t?.cause!==void 0&&(this.cause=t.cause),Object.setPrototypeOf(this,new.target.prototype)}},O=class extends y{timeoutMs;constructor(e,t){super(`[urun] request timed out after ${e}ms`,{requestId:t}),this.name="RequestTimeoutError",this.timeoutMs=e,Object.setPrototypeOf(this,new.target.prototype)}},U=class extends y{timeoutMs;constructor(e,t){super(`[urun] request doc-sync did not establish within ${e}ms \u2014 the request was never delivered to the runtime (the session doc never synced with the session-server; check the doc-sync transport / connection)`,{requestId:t}),this.name="RequestDocSyncError",this.timeoutMs=e,Object.setPrototypeOf(this,new.target.prototype)}},k=class extends y{constructor(e){super("[urun] request aborted",{requestId:e}),this.name="RequestAbortError",Object.setPrototypeOf(this,new.target.prototype)}},C=class extends y{constructor(e){super("[urun] request cancelled: session disconnected",{requestId:e}),this.name="RequestCancelledError",Object.setPrototypeOf(this,new.target.prototype)}};var Le=new Set,De="rpc",je="llm",pe=3e4,Be="llm-resp";function $e(n){return`${Be}:${n}`}function V(){return re()}function Ne(n){if(n&&typeof n=="object"){let e=n.error;if(e&&typeof e=="object"){let{message:t,code:r}=e;return{message:typeof t=="string"?t:JSON.stringify(e),code:typeof r=="string"?r:void 0}}if(typeof e=="string")return{message:e}}return{message:typeof n=="string"?n:JSON.stringify(n)}}function Fe(n,e,t,r,s,o,i,u,h){let p=[],d=null,a=!1,l=null,g=!1,f,w,_=new Promise((c,b)=>{f=c,w=b});_.catch(()=>{});let S=o(),m=null,v=null,R=null,q=null,L=!0,Q=()=>{R&&(clearTimeout(R),R=null),q&&(q(),q=null)},D=()=>{L=!1,Q(),m?.(),m=null,v?.(),v=null,i?.removeEventListener("abort",ee),S.dispose(),g&&n.set({requests:{[e]:null}})},G=()=>{if(d){if(p.length>0){let c=d;d=null,c.resolve({value:p.shift(),done:!1})}else if(l!==null){let c=d;d=null,c.reject(l)}else if(a){let c=d;d=null,c.resolve({value:void 0,done:!0})}}},me=c=>{a||(p.push(c),G())},T=c=>{a||(l=c,a=!0,w(c),D(),G())},Z=c=>{a||(a=!0,f(c),D(),G())},ee=()=>T(new k(e)),ge=c=>{if(!(a||!c||typeof c!="object"))switch(c.t){case"delta":typeof c.delta=="string"&&me(c.delta);break;case"response":Z(c.body);break;case"error":{let{message:b,code:E}=Ne(c.body);T(new y(b,{requestId:e,code:c.code??E}));break}}},we=()=>{let c=S.messages()[Symbol.asyncIterator]();m=()=>{c.return?.(void 0)};let b=()=>{L&&c.next().then(E=>{if(L){if(E.done){a||Z(void 0);return}ge(E.value),b()}},E=>{L&&T(E)})};b()},te=()=>{if(!g){if(g=!0,i){if(i.aborted){T(new k(e));return}i.addEventListener("abort",ee,{once:!0})}v=u?.(c=>T(c))??null,we(),n.set({requests:{[e]:{payload:t,consumer_id:r,stream:s}}}),h&&h>0&&!n.synced&&(R=setTimeout(()=>{R=null,!a&&!n.synced&&T(new U(h,e))},h),q=n.onSynced(()=>Q()))}};return{deltas:{[Symbol.asyncIterator](){return{next(){if(te(),p.length>0)return Promise.resolve({value:p.shift(),done:!1});if(l!==null){let c=l;return l=null,Promise.reject(c)}return a?Promise.resolve({value:void 0,done:!0}):new Promise((c,b)=>{d={resolve:c,reject:b}})},return(){return a||(a=!0,f(void 0),D()),Promise.resolve({value:void 0,done:!0})},throw(c){return a||(a=!0,w(c),D()),Promise.reject(c)}}}},body:_,start:te}}function Ge(n,e){return[`streams/${n}/${e}`,`streams/${n}/*`]}var z=class{constructor(e,t,r){this._name=e;this._transport=t;this._laneDoc=r;this._track=this._transport.getTrackByName(this._name)??null,this._unsubscribeTransport=this._transport.on("track",()=>{let s=this._transport.getTrackByName(this._name)??null;s!==this._track&&this._setTrack(s)})}_name;_transport;_laneDoc;_track=null;_handlers=new Map;_unsubscribeTransport=null;_subscribed=!1;_messageConsumers=new Set;_laneUnsubs=[];_laneSeen=new Map;_replay=[];_disposed=!1;messages(){this._ensureSubscribed();let e=this;return{[Symbol.asyncIterator](){let t=[...e._replay],r=null,s=!1,o={push(u){if(!s)if(r){let h=r;r=null,h({value:u,done:!1})}else t.push(u)},end(){if(s=!0,r){let u=r;r=null,u({value:void 0,done:!0})}}};e._messageConsumers.add(o);let i=()=>{s=!0,e._messageConsumers.delete(o)};return{next(){return t.length>0?Promise.resolve({value:t.shift(),done:!1}):s?Promise.resolve({value:void 0,done:!0}):new Promise(u=>{r=u})},return(){return i(),Promise.resolve({value:void 0,done:!0})}}}}}_ensureSubscribed(){if(!(this._subscribed||this._disposed)&&(this._subscribed=!0,this._transport.subscribeStream(this._name),!!this._laneDoc))for(let e of Ge(this._name,this._transport.consumerId)){let t=this._laneDoc(e);this._laneSeen.set(e,0);let r=s=>this._drainLane(e,s);r(t.get()),this._laneUnsubs.push(t.on("change",r))}}_drainLane(e,t){let r=t.messages;if(!Array.isArray(r))return;let s=this._laneSeen.get(e)??0;for(;s<r.length;s++){let o=r[s];this._replay.push(o);for(let i of this._messageConsumers)i.push(o)}this._laneSeen.set(e,s)}get track(){let e=this._transport.getTrackByName(this._name)??this._track;return e!==this._track&&this._setTrack(e),this._track}async attach(e){await this._transport.addTrack(e)}async attachVideo(e){await this._transport.addVideoTrack(e)}async detach(){this._transport.removeTrack()}async detachVideo(){this._transport.stopVideo()}async seek(e){if(e!=="live"&&(!Number.isFinite(e)||e<0))throw new Error('[urun] stream.seek target must be "live" or a non-negative number of seconds');this._transport.seekStream(this._name,e)}on(e,t){let r=this._handlers.get(e);return r||(r=new Set,this._handlers.set(e,r)),r.add(t),()=>{r?.delete(t),r?.size===0&&this._handlers.delete(e)}}dispose(){this._disposed=!0,this._unsubscribeTransport?.(),this._unsubscribeTransport=null,this._handlers.clear(),this._subscribed&&this._transport.unsubscribeStream(this._name);for(let e of this._laneUnsubs)e();this._laneUnsubs=[];for(let e of this._messageConsumers)e.end();this._messageConsumers.clear()}_setTrack(e){this._track=e,e&&e.addEventListener("ended",()=>{this._track===e&&this._setTrack(null)},{once:!0});let t=this._handlers.get("track");if(t)for(let r of t)r(e)}},M=class n{_sessionId;_multiplexer;_transport;_docs=new Map;_streams=new Map;_activeRequests=new Set;constructor(e,t,r){this._sessionId=e,this._multiplexer=t,this._transport=r,this._wireControlDocIncarnation()}_wireControlDocIncarnation(){let e=this.doc("control");this._transport.applyControlDocState(e.get()),e.on("change",t=>{this._transport.applyControlDocState(t)})}static async attach(e,t){let r=await ie({baseUrl:t.baseUrl,fallbackUrls:t.fallbackUrls,sessionId:e,orgId:t.orgId,jwt:t.jwt,getAccessToken:t.getAccessToken,authProvider:t.authProvider}),s=t.getAccessToken?await t.getAccessToken()??void 0:t.jwt,o=new j,i=new B({url:r.wsUrl,orgId:t.orgId,jwt:s,authProvider:t.authProvider,sessionId:e,iceServers:r.response.ice_servers}),u=new n(e,o,i);return i.on("connected",()=>{i.multiplexer&&o.setTarget(i.multiplexer)}),i.setConnection({url:r.wsUrl,sessionId:e,iceServers:r.response.ice_servers}),await i.connect({role:"viewer"}),u}get id(){return this._sessionId}get phase(){return this._transport.phase}onPhase(e){return e(this._transport.phase),this._transport.on("phase",e)}setSessionId(e){if(e===this._sessionId)return;this._multiplexer.rewriteSessionChannels?.call(this._multiplexer,this._sessionId,e),this._sessionId=e;for(let r of this._docs.values())r.setSessionId(e)}stream(e){let t=this._streams.get(e);return t||(t=new z(e,this._transport,r=>this.doc(r)),this._streams.set(e,t)),t}doc(e){let t=this._docs.get(e);return t||(t=new F(e,this._sessionId,Le.has(e)?null:this._transport),this._docs.set(e,t)),t}sendImage(e){this.doc("control").set({desired:{reference_image:{value:e}}})}request(e,t={}){let r=this.doc(De),s=V();return new Promise((o,i)=>{let u=!1,h=null,p=null,d=null,a=()=>{p&&(clearTimeout(p),p=null),h&&(h(),h=null),d&&(this._activeRequests.delete(d),d=null),t.signal?.removeEventListener("abort",g),r.set({requests:{[s]:null}})},l=w=>{u||(u=!0,a(),w())},g=()=>l(()=>i(new k(s)));if(t.signal){if(t.signal.aborted){u=!0,i(new k(s));return}t.signal.addEventListener("abort",g,{once:!0})}let f=w=>{let S=w.responses?.[s];if(S==null)return;let m=S;if(m.error!==void 0&&m.error!==null){let v=typeof m.error=="string"?m.error:JSON.stringify(m.error);l(()=>i(new y(v,{requestId:s,code:m.code})))}else l(()=>o(m.result))};h=r.on("change",f),d=w=>l(()=>i(w)),this._activeRequests.add(d),typeof t.timeout=="number"&&t.timeout>=0&&(p=setTimeout(()=>l(()=>i(new O(t.timeout,s))),t.timeout)),r.set({requests:{[s]:{payload:e}}}),f(r.get())})}_consumeResponse(e,t,r,s,o){let i=this.doc(je);return Fe(i,e,t,this._transport.consumerId,r,()=>this.stream($e(e)),s,u=>(this._activeRequests.add(u),()=>this._activeRequests.delete(u)),o??pe)}requestStream(e,t={}){let r=V();return this._consumeResponse(r,e,!0,t.signal,t.docSyncTimeout).deltas}complete(e,t={}){let r=V(),s=this._consumeResponse(r,e,!1,t.signal,t.docSyncTimeout);return s.start(),s.body}disconnect(){let e=Array.from(this._activeRequests);this._activeRequests.clear();for(let t of e)try{t(new C)}catch{}for(let t of this._docs.values())t.dispose();this._docs.clear();for(let t of this._streams.values())t.dispose();this._streams.clear(),this._transport.disconnect()}};var Ke=new Set(["then","catch","finally","toJSON",Symbol.toPrimitive]);function We(n,e){return new Proxy({},{get(t,r){if(!(Ke.has(r)||typeof r!="string"))return s=>{let o=s??{},i=()=>`s_${Date.now()}_${Math.random().toString(36).slice(2)}`,u=i(),h=new j,p=new B({url:"",orgId:e.orgId,jwt:e.jwt,authProvider:e.authProvider,sessionId:u}),d=new M(u,h,p),a=async l=>{let g=await oe({baseUrl:e.baseUrl,fallbackUrls:e.fallbackUrls,app:n,functionName:r,orgId:e.orgId,jwt:e.jwt,getAccessToken:e.getAccessToken,authProvider:e.authProvider,idempotencyKey:l}),f=e.getAccessToken?await e.getAccessToken()??void 0:e.jwt;return d.setSessionId(g.sessionId),{url:g.wsUrl,sessionId:g.sessionId,jwt:f,iceServers:g.response.ice_servers}};return p.setConnectionResolver(()=>a(i())),p.on("connected",()=>{p.multiplexer&&h.setTarget(p.multiplexer)}),(async()=>{let l=await a(u);p.setAuth({jwt:l.jwt,authProvider:e.authProvider,orgId:e.orgId}),p.setConnection({url:l.url,sessionId:l.sessionId,iceServers:l.iceServers}),await p.connect({app:n,functionName:r,args:o})})().catch(l=>{console.error(`[urun] Failed to connect session for ${r}:`,l)}),d}}})}var fe=3e4,he="stream:",X=class{_ws;_multiplexer;_pendingRpc=new Map;_rpcId=0;constructor(e,t){this._ws=e,this._multiplexer=t,this._ws.addEventListener("message",r=>{let s;try{s=JSON.parse(typeof r.data=="string"?r.data:"")}catch{return}if(s.rpcId&&this._pendingRpc.has(s.rpcId)){let o=this._pendingRpc.get(s.rpcId);this._pendingRpc.delete(s.rpcId),clearTimeout(o.timer),s.error?o.reject(new Error(s.error)):o.resolve(s.result)}})}async get(e){return this._sendRpc("store.get",{key:e})}async has(e){return await this._sendRpc("store.has",{key:e})}on(e,t){let r=`${he}${e}`;return this._multiplexer.on(r,s=>{t(s)})}emit(e,t){let r=`${he}${e}`,s=typeof t=="object"&&t!==null&&!Array.isArray(t)?t:{data:t};this._multiplexer.emit(r,s)}_getInternals(){return{multiplexer:this._multiplexer,ws:this._ws}}_sendRpc(e,t){return new Promise((r,s)=>{if(!this._ws||this._ws.readyState!==WebSocket.OPEN){s(new Error("WebSocket not open"));return}let o=String(++this._rpcId),i=setTimeout(()=>{this._pendingRpc.has(o)&&(this._pendingRpc.delete(o),s(new Error(`RPC request "${e}" timed out after ${fe}ms`)))},fe);this._pendingRpc.set(o,{resolve:r,reject:s,timer:i}),this._ws.send(JSON.stringify({rpcId:o,type:e,...t}))})}};function Ye(n){let r=`${n.baseUrl.replace(/\/$/,"").replace(/^http/,"ws")}/store/${encodeURIComponent(n.orgId)}`,s=new WebSocket(r);(n.jwt||n.apiKey)&&s.addEventListener("open",()=>{s.send(JSON.stringify({type:"auth",orgId:n.orgId,jwt:n.jwt,authProvider:n.authProvider,apiKey:n.apiKey}))});let o=new ne(s);return new X(s,o)}var Je='video/mp4; codecs="avc1.42E01E"';function He(n,e){let t=e?.codec??Je,r=document.createElement("video");r.muted=!0,r.playsInline=!0;let s=new MediaSource,o=URL.createObjectURL(s);r.src=o,s.addEventListener("sourceopen",()=>{let l;try{l=s.addSourceBuffer(t)}catch(_){throw _ instanceof DOMException&&_.name==="NotSupportedError"?new Error(`Codec not supported: "${t}". Ensure the codec string matches the fMP4 container format. Common values: video/mp4; codecs="avc1.42E01E" (H.264 Baseline), video/mp4; codecs="avc1.4D401F" (H.264 Main).`):_}let g=n.getReader();function f(){return l.updating?new Promise(_=>{l.addEventListener("updateend",()=>_(),{once:!0})}):Promise.resolve()}async function w(){try{for(;;){let{done:_,value:S}=await g.read();if(_){await f(),s.readyState==="open"&&s.endOfStream();return}await f();try{l.appendBuffer(S)}catch(m){if(m instanceof DOMException&&m.name==="QuotaExceededError"){let v=l.buffered;if(v.length>0){let R=v.start(v.length-1);l.remove(0,R),await f(),l.appendBuffer(S)}else throw m}else throw m}}}catch{if(s.readyState==="open")try{s.endOfStream("decode")}catch{}}}w()}),r.play().catch(()=>{});let i=r,u=i.captureStream??i.mozCaptureStream;if(!u)throw new Error("captureStream() is not supported in this browser. videoStream() requires HTMLMediaElement.captureStream() support.");let h=u.call(r),p=h.getTracks(),d=0,a=p.length;if(a===0)r.addEventListener("emptied",()=>{URL.revokeObjectURL(o)},{once:!0});else for(let l of p)l.addEventListener("ended",()=>{d++,d>=a&&URL.revokeObjectURL(o)});return h}export{We as App,pe as DEFAULT_DOC_SYNC_TIMEOUT_MS,k as RequestAbortError,C as RequestCancelledError,U as RequestDocSyncError,y as RequestError,O as RequestTimeoutError,M as Session,Ye as createStore,He as videoStream};
1
+ import{a as ne,b as B,f as se,i as $}from"./chunk-4O3YOYT6.mjs";import"./chunk-FNR7JDXN.mjs";var ye="session-api.prod.cloud.urun.sh",Se=["https://session-api.use2.prod.cloud.urun.sh","https://session-api.usw2.prod.cloud.urun.sh"];function N(n){return n.trim().replace(/\/+$/,"")}function oe(n,e){let t=[],r=s=>{if(!s)return;let o=N(s);o&&!t.includes(o)&&t.push(o)};r(n);for(let s of e??[])r(s);for(let s of xe(n))r(s);return t}var ve=120,be=1e3,ke=3;function Re(n){if(!n)return null;try{let e=new URL(n),t=e.pathname.replace(/\/api\/sessions\/create\/?$/,"");return N(`${e.origin}${t}`)}catch{return null}}async function ie(n){let e=oe(n.baseUrl,n.fallbackUrls),t=null,r=e.length>1;for(let s of e)try{return await Ae(s,n,{pollAttempts:ve,retryAfterLimitMs:r?be:void 0})}catch(o){if(t=o instanceof Error?o:new Error(String(o)),t instanceof A)throw t}throw t??new Error("[urun] session allocation failed")}async function Ae(n,e,t){let r,s,o,i=n,u=0,h=new Set;for(let p=0;p<t.pollAttempts;p++){s=o??await Y(e),o=void 0;let d=r?await fetch(`${i}/api/session-requests/${encodeURIComponent(r)}`,{headers:W(e,s)}):await fetch(`${i}/api/sessions/create`,{method:"POST",redirect:"manual",headers:{...W(e,s),"Content-Type":"application/json","Idempotency-Key":e.idempotencyKey},body:JSON.stringify(Ie(e))});if(!r&&(d.status===307||d.status===308)){let f=Re(d.headers.get("location"));if(f&&f!==i&&u<ke){u+=1,i=f;continue}throw new Error(`[urun] session create redirected from ${i} without a usable target`)}let a=await ce(d);if(d.ok&&(a.status==="allocated"||!a.status&&!!a.session_id)&&!!a.session_id){let f=a.session_id;if(!a.ws_url)throw new A(`[urun] gateway allocated session ${f} without ws_url`);if(!ue(a.ws_url))throw new A(`[urun] gateway allocated session ${f} with non-absolute ws_url`);return{baseUrl:i,sessionId:f,wsUrl:a.ws_url,response:a}}if(d.status===202||a.status==="pending"||a.status==="queued"||a.queued){if(r=a.request_id||r,!r)throw new Error("[urun] gateway queued session without request_id");await Pe(Te(d,a,t.retryAfterLimitMs));continue}if((d.status===401||d.status===403)&&e.getAccessToken){let f=s??"";h.add(f);let w=await Y(e,{forceRefresh:!0,reason:"unauthorized"});if(w&&!h.has(w)){o=w,r=void 0;continue}}let g=a.error_message||a.error_code||`HTTP ${d.status}`;throw new Error(`[urun] session allocation failed at ${i}: ${g}`)}throw new Error(`[urun] timed out waiting for session allocation at ${i}`)}function W(n,e){let t={"X-Tenant-Id":n.orgId,"X-Auth-Provider":n.authProvider||"default","X-User-Id":"anonymous"};return e&&(t.Authorization=`Bearer ${e}`),t}async function Y(n,e){return n.getAccessToken?await n.getAccessToken(e)??void 0:n.jwt}function Ie(n){return{app:n.app,function:n.functionName,gpus:1,idempotency_key:n.idempotencyKey}}async function ae(n){let e=oe(n.baseUrl,n.fallbackUrls),t=null;for(let r of e)try{let s={baseUrl:r,app:"",functionName:"",orgId:n.orgId,jwt:n.jwt,getAccessToken:n.getAccessToken,authProvider:n.authProvider,idempotencyKey:""},o=await Y(s),i=await fetch(`${N(r)}/api/sessions/${encodeURIComponent(n.sessionId)}/viewer-connect`,{headers:W(s,o)});if(!i.ok)throw new Error(`[urun] viewer-connect for ${n.sessionId} failed: HTTP ${i.status}`);let u=await ce(i);if(!u.ws_url||!ue(u.ws_url))throw new A(`[urun] viewer-connect returned no usable ws_url for ${n.sessionId}`);return{baseUrl:N(r),sessionId:n.sessionId,wsUrl:u.ws_url,response:u}}catch(s){if(t=s instanceof Error?s:new Error(String(s)),t instanceof A)throw t}throw t??new Error("[urun] viewer-connect failed")}async function ce(n){try{let e=await n.json();return e&&typeof e=="object"?e:{}}catch{return{}}}function Te(n,e,t){let r=Number(n.headers.get("Retry-After")||""),s=Number(e.retry_after_seconds??r),o=t??1e4;return Number.isFinite(s)&&s>0?Math.min(s*1e3,o):1e3}function Pe(n){return new Promise(e=>setTimeout(e,n))}var A=class extends Error{};function ue(n){try{let e=new URL(n);return e.protocol==="ws:"||e.protocol==="wss:"}catch{return!1}}function xe(n){try{return new URL(n).hostname!==ye?[]:Se}catch{return[]}}import*as x from"yjs";var le=Symbol("urun:doc:remote"),Ee=Symbol("urun:doc:local");function I(n){return n!==null&&typeof n=="object"&&!Array.isArray(n)}var F="$bytes";function Oe(n){return n instanceof Uint8Array||n instanceof ArrayBuffer}function Ue(n){if(!I(n))return!1;let e=Object.keys(n);return e.length===1&&e[0]===F&&typeof n[F]=="string"}function Ce(n){return n instanceof ArrayBuffer?new Uint8Array(n):n}function Me(n){if(typeof Buffer<"u")return Buffer.from(n).toString("base64");let e="";for(let t=0;t<n.length;t++)e+=String.fromCharCode(n[t]);return btoa(e)}function De(n){if(typeof Buffer<"u")return new Uint8Array(Buffer.from(n,"base64"));let e=atob(n),t=new Uint8Array(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}function J(n){if(Oe(n))return{[F]:Me(Ce(n))};if(Array.isArray(n))return n.map(J);if(I(n)){let e={};for(let[t,r]of Object.entries(n))e[t]=J(r);return e}return n}function E(n){if(Ue(n))return De(n[F]);if(Array.isArray(n))return n.map(E);if(I(n)){let e={};for(let[t,r]of Object.entries(n))e[t]=E(r);return e}return n}function H(n,e){let t={...n};for(let r of Object.keys(e)){let s=e[r],o=t[r];I(s)&&I(o)?t[r]=H(o,s):t[r]=s}return t}var pe=Symbol("urun:doc:path-absent");function qe(n,e){let t=e.split("."),r=n;for(let s of t){if(r===null||typeof r!="object"||!(s in r))return pe;r=r[s]}return r}function de(n){return n===void 0?n:JSON.parse(JSON.stringify(n))}var K=class{_doc=new x.Doc;_root=this._doc.getMap("session");_listeners=new Set;_key;_sessionId;_transport;_transportUnsubs=[];_synced;_pendingPatches=[];_syncWaiters=new Set;_texts=new Map;_observer=()=>this.notify();_updateHandler=(e,t)=>{t!==le&&this._transport?.sendDocSync(this._key,e)};constructor(e,t,r){this._key=e,this._sessionId=t,this._transport=r??null,this._synced=this._transport===null,this._root.observeDeep(this._observer),this._doc.on("update",this._updateHandler),this._transport&&(this._transportUnsubs.push(this._transport.onDocSync(this._key,s=>this.applyRemote(s)),this._transport.onDocSyncReady(()=>this.sendHello())),this._transport.isOpen&&this.sendHello())}setSessionId(e){this._sessionId=e}get synced(){return this._synced}onSynced(e){return this._synced?(e(),()=>{}):(this._syncWaiters.add(e),()=>this._syncWaiters.delete(e))}set(e){if(e=J(e),!this._synced){this._pendingPatches.push(de(e)),this.notify();return}this.applyPatch(e)}get(e,t){let r=this.snapshot();if(!e)return E(r);let s=qe(r,e);return s===pe?t:E(s)}on(e,t){return this._listeners.add(t),()=>this._listeners.delete(t)}text(e){let t=this._texts.get(e);return t||(t=new V(this._doc.getText(`text:${e}`)),this._texts.set(e,t)),t}dispose(){this._root.unobserveDeep(this._observer),this._doc.off("update",this._updateHandler);for(let e of this._transportUnsubs)e();this._transportUnsubs=[],this._transport=null,this._listeners.clear(),this._syncWaiters.clear();for(let e of this._texts.values())e.dispose();this._texts.clear(),this._doc.destroy()}sendHello(){this._transport&&this._transport.sendDocSync(this._key,x.encodeStateAsUpdate(this._doc))}applyRemote(e){if(x.applyUpdate(this._doc,e,le),!this._synced){this._synced=!0;let t=this._pendingPatches.splice(0);for(let s of t)this.applyPatch(s);let r=[...this._syncWaiters];this._syncWaiters.clear();for(let s of r)s()}}applyPatch(e){this._doc.transact(()=>{let t=this._root.toJSON();for(let[r,s]of Object.entries(e)){let o=t[r],i=I(s)&&I(o)?H(o,s):de(s);JSON.stringify(i)!==JSON.stringify(o)&&this._root.set(r,i)}},Ee)}snapshot(){let e=this._root.toJSON();for(let t of this._pendingPatches)e=H(e,t);return e}notify(){let e=E(this.snapshot());for(let t of this._listeners)t(e)}},V=class{constructor(e){this._ytext=e;this._observer=t=>{for(let r of t.delta)if(typeof r.insert=="string"&&r.insert.length>0){let s=r.insert;for(let o of this._delta)o(s)}},this._ytext.observe(this._observer)}_ytext;_delta=new Set;_observer;append(e){e.length!==0&&this._ytext.insert(this._ytext.length,e)}toString(){return this._ytext.toString()}get length(){return this._ytext.length}on(e,t){return this._delta.add(t),()=>this._delta.delete(t)}dispose(){this._ytext.unobserve(this._observer),this._delta.clear()}};var y=class extends Error{requestId;code;constructor(e,t){super(e),this.name="RequestError",this.requestId=t?.requestId,this.code=t?.code,t?.cause!==void 0&&(this.cause=t.cause),Object.setPrototypeOf(this,new.target.prototype)}},O=class extends y{timeoutMs;constructor(e,t){super(`[urun] request timed out after ${e}ms`,{requestId:t}),this.name="RequestTimeoutError",this.timeoutMs=e,Object.setPrototypeOf(this,new.target.prototype)}},U=class extends y{timeoutMs;constructor(e,t){super(`[urun] request doc-sync did not establish within ${e}ms \u2014 the request was never delivered to the runtime (the session doc never synced with the session-server; check the doc-sync transport / connection)`,{requestId:t}),this.name="RequestDocSyncError",this.timeoutMs=e,Object.setPrototypeOf(this,new.target.prototype)}},C=class extends Error{stream;owner;attempted;constructor(e,t,r){super(`[urun] stream "${e}" is already produced by the ${t}; this (${r}) peer cannot also produce it \u2014 a named stream has exactly one producer (consume it instead, or use a distinct name for the reverse direction)`),this.name="StreamDirectionConflict",this.stream=e,this.owner=t,this.attempted=r,Object.setPrototypeOf(this,new.target.prototype)}},k=class extends y{constructor(e){super("[urun] request aborted",{requestId:e}),this.name="RequestAbortError",Object.setPrototypeOf(this,new.target.prototype)}},M=class extends y{constructor(e){super("[urun] request cancelled: session disconnected",{requestId:e}),this.name="RequestCancelledError",Object.setPrototypeOf(this,new.target.prototype)}};var Le=new Set,je="rpc",Be="llm",fe=3e4,$e="llm-resp";function Ne(n){return`${$e}:${n}`}function z(){return se()}function Fe(n){if(n&&typeof n=="object"){let e=n.error;if(e&&typeof e=="object"){let{message:t,code:r}=e;return{message:typeof t=="string"?t:JSON.stringify(e),code:typeof r=="string"?r:void 0}}if(typeof e=="string")return{message:e}}return{message:typeof n=="string"?n:JSON.stringify(n)}}function Ke(n,e,t,r,s,o,i,u,h){let p=[],d=null,a=!1,l=null,g=!1,f,w,_=new Promise((c,b)=>{f=c,w=b});_.catch(()=>{});let S=o(),m=null,v=null,R=null,q=null,L=!0,Z=()=>{R&&(clearTimeout(R),R=null),q&&(q(),q=null)},j=()=>{L=!1,Z(),m?.(),m=null,v?.(),v=null,i?.removeEventListener("abort",te),S.dispose(),g&&n.set({requests:{[e]:null}})},G=()=>{if(d){if(p.length>0){let c=d;d=null,c.resolve({value:p.shift(),done:!1})}else if(l!==null){let c=d;d=null,c.reject(l)}else if(a){let c=d;d=null,c.resolve({value:void 0,done:!0})}}},ge=c=>{a||(p.push(c),G())},T=c=>{a||(l=c,a=!0,w(c),j(),G())},ee=c=>{a||(a=!0,f(c),j(),G())},te=()=>T(new k(e)),we=c=>{if(!(a||!c||typeof c!="object"))switch(c.t){case"delta":typeof c.delta=="string"&&ge(c.delta);break;case"response":ee(c.body);break;case"error":{let{message:b,code:P}=Fe(c.body);T(new y(b,{requestId:e,code:c.code??P}));break}}},_e=()=>{let c=S.messages()[Symbol.asyncIterator]();m=()=>{c.return?.(void 0)};let b=()=>{L&&c.next().then(P=>{if(L){if(P.done){a||ee(void 0);return}we(P.value),b()}},P=>{L&&T(P)})};b()},re=()=>{if(!g){if(g=!0,i){if(i.aborted){T(new k(e));return}i.addEventListener("abort",te,{once:!0})}v=u?.(c=>T(c))??null,_e(),n.set({requests:{[e]:{payload:t,consumer_id:r,stream:s}}}),h&&h>0&&!n.synced&&(R=setTimeout(()=>{R=null,!a&&!n.synced&&T(new U(h,e))},h),q=n.onSynced(()=>Z()))}};return{deltas:{[Symbol.asyncIterator](){return{next(){if(re(),p.length>0)return Promise.resolve({value:p.shift(),done:!1});if(l!==null){let c=l;return l=null,Promise.reject(c)}return a?Promise.resolve({value:void 0,done:!0}):new Promise((c,b)=>{d={resolve:c,reject:b}})},return(){return a||(a=!0,f(void 0),j()),Promise.resolve({value:void 0,done:!0})},throw(c){return a||(a=!0,w(c),j()),Promise.reject(c)}}}},body:_,start:re}}function Ge(n,e){return[`streams/${n}/${e}`,`streams/${n}/*`]}function We(n,e){return`streams/${n}/${e??"*"}`}function Ye(n,e){let r=n.get("streams")?.[e];if(r&&typeof r=="object"){let{producer:s,epoch:o}=r;if(s==="runtime"||s==="browser")return{producer:s,epoch:typeof o=="number"?o:0}}return null}var X=class{constructor(e,t,r,s){this._name=e;this._transport=t;this._laneDoc=r;this._controlDoc=s;this._track=this._transport.getTrackByName(this._name)??null,this._unsubscribeTransport=this._transport.on("track",()=>{let o=this._transport.getTrackByName(this._name)??null;o!==this._track&&this._setTrack(o)})}_name;_transport;_laneDoc;_controlDoc;_track=null;_handlers=new Map;_unsubscribeTransport=null;_subscribed=!1;_messageConsumers=new Set;_laneUnsubs=[];_laneSeen=new Map;_replay=[];_disposed=!1;messages(){this._ensureSubscribed();let e=this;return{[Symbol.asyncIterator](){let t=[...e._replay],r=null,s=!1,o={push(u){if(!s)if(r){let h=r;r=null,h({value:u,done:!1})}else t.push(u)},end(){if(s=!0,r){let u=r;r=null,u({value:void 0,done:!0})}}};e._messageConsumers.add(o);let i=()=>{s=!0,e._messageConsumers.delete(o)};return{next(){return t.length>0?Promise.resolve({value:t.shift(),done:!1}):s?Promise.resolve({value:void 0,done:!0}):new Promise(u=>{r=u})},return(){return i(),Promise.resolve({value:void 0,done:!0})}}}}}_ensureSubscribed(){if(!(this._subscribed||this._disposed)&&(this._subscribed=!0,this._transport.subscribeStream(this._name),!!this._laneDoc))for(let e of Ge(this._name,this._transport.consumerId)){let t=this._laneDoc(e);this._laneSeen.set(e,0);let r=s=>this._drainLane(e,s);r(t.get()),this._laneUnsubs.push(t.on("change",r))}}_drainLane(e,t){let r=t.messages;if(!Array.isArray(r))return;let s=this._laneSeen.get(e)??0;for(;s<r.length;s++){let o=r[s];this._replay.push(o);for(let i of this._messageConsumers)i.push(o)}this._laneSeen.set(e,s)}get track(){let e=this._transport.getTrackByName(this._name)??this._track;return e!==this._track&&this._setTrack(e),this._track}_claimBrowserProducer(){if(!this._controlDoc)return;let e=this._controlDoc(),t=Ye(e,this._name);if(t&&t.producer==="runtime")throw new C(this._name,"runtime","browser");if(t&&t.producer==="browser")return;let r=(typeof t?.epoch=="number"?t.epoch:0)+1;e.set({streams:{[this._name]:{producer:"browser",epoch:r}}})}async attach(e){this._claimBrowserProducer(),await this._transport.addTrack(e)}async attachVideo(e){this._claimBrowserProducer(),await this._transport.addVideoTrack(e)}async emit(e,t={}){if(this._claimBrowserProducer(),!this._laneDoc)throw new Error("[urun] stream.emit requires the session doc transport (no laneDoc wired)");let r=We(this._name,t.to),s=this._laneDoc(r),o=s.get("messages"),i=Array.isArray(o)?[...o]:[];i.push(e),s.set({messages:i})}async detach(){this._transport.removeTrack()}async detachVideo(){this._transport.stopVideo()}async seek(e){if(e!=="live"&&(!Number.isFinite(e)||e<0))throw new Error('[urun] stream.seek target must be "live" or a non-negative number of seconds');this._transport.seekStream(this._name,e)}on(e,t){let r=this._handlers.get(e);return r||(r=new Set,this._handlers.set(e,r)),r.add(t),()=>{r?.delete(t),r?.size===0&&this._handlers.delete(e)}}dispose(){this._disposed=!0,this._unsubscribeTransport?.(),this._unsubscribeTransport=null,this._handlers.clear(),this._subscribed&&this._transport.unsubscribeStream(this._name);for(let e of this._laneUnsubs)e();this._laneUnsubs=[];for(let e of this._messageConsumers)e.end();this._messageConsumers.clear()}_setTrack(e){this._track=e,e&&e.addEventListener("ended",()=>{this._track===e&&this._setTrack(null)},{once:!0});let t=this._handlers.get("track");if(t)for(let r of t)r(e)}},D=class n{_sessionId;_multiplexer;_transport;_docs=new Map;_streams=new Map;_activeRequests=new Set;constructor(e,t,r){this._sessionId=e,this._multiplexer=t,this._transport=r,this._wireControlDocIncarnation()}_wireControlDocIncarnation(){let e=this.doc("control");this._transport.applyControlDocState(e.get()),e.on("change",t=>{this._transport.applyControlDocState(t)})}static async attach(e,t){let r=await ae({baseUrl:t.baseUrl,fallbackUrls:t.fallbackUrls,sessionId:e,orgId:t.orgId,jwt:t.jwt,getAccessToken:t.getAccessToken,authProvider:t.authProvider}),s=t.getAccessToken?await t.getAccessToken()??void 0:t.jwt,o=new B,i=new $({url:r.wsUrl,orgId:t.orgId,jwt:s,authProvider:t.authProvider,sessionId:e,iceServers:r.response.ice_servers}),u=new n(e,o,i);return i.on("connected",()=>{i.multiplexer&&o.setTarget(i.multiplexer)}),i.setConnection({url:r.wsUrl,sessionId:e,iceServers:r.response.ice_servers}),await i.connect({role:"viewer"}),u}get id(){return this._sessionId}get phase(){return this._transport.phase}onPhase(e){return e(this._transport.phase),this._transport.on("phase",e)}setSessionId(e){if(e===this._sessionId)return;this._multiplexer.rewriteSessionChannels?.call(this._multiplexer,this._sessionId,e),this._sessionId=e;for(let r of this._docs.values())r.setSessionId(e)}stream(e){let t=this._streams.get(e);return t||(t=new X(e,this._transport,r=>this.doc(r),()=>this.doc("control")),this._streams.set(e,t)),t}doc(e){let t=this._docs.get(e);return t||(t=new K(e,this._sessionId,Le.has(e)?null:this._transport),this._docs.set(e,t)),t}sendImage(e){this.doc("control").set({desired:{reference_image:{value:e}}})}request(e,t={}){let r=this.doc(je),s=z();return new Promise((o,i)=>{let u=!1,h=null,p=null,d=null,a=()=>{p&&(clearTimeout(p),p=null),h&&(h(),h=null),d&&(this._activeRequests.delete(d),d=null),t.signal?.removeEventListener("abort",g),r.set({requests:{[s]:null}})},l=w=>{u||(u=!0,a(),w())},g=()=>l(()=>i(new k(s)));if(t.signal){if(t.signal.aborted){u=!0,i(new k(s));return}t.signal.addEventListener("abort",g,{once:!0})}let f=w=>{let S=w.responses?.[s];if(S==null)return;let m=S;if(m.error!==void 0&&m.error!==null){let v=typeof m.error=="string"?m.error:JSON.stringify(m.error);l(()=>i(new y(v,{requestId:s,code:m.code})))}else l(()=>o(m.result))};h=r.on("change",f),d=w=>l(()=>i(w)),this._activeRequests.add(d),typeof t.timeout=="number"&&t.timeout>=0&&(p=setTimeout(()=>l(()=>i(new O(t.timeout,s))),t.timeout)),r.set({requests:{[s]:{payload:e}}}),f(r.get())})}_consumeResponse(e,t,r,s,o){let i=this.doc(Be);return Ke(i,e,t,this._transport.consumerId,r,()=>this.stream(Ne(e)),s,u=>(this._activeRequests.add(u),()=>this._activeRequests.delete(u)),o??fe)}requestStream(e,t={}){let r=z();return this._consumeResponse(r,e,!0,t.signal,t.docSyncTimeout).deltas}complete(e,t={}){let r=z(),s=this._consumeResponse(r,e,!1,t.signal,t.docSyncTimeout);return s.start(),s.body}disconnect(){let e=Array.from(this._activeRequests);this._activeRequests.clear();for(let t of e)try{t(new M)}catch{}for(let t of this._docs.values())t.dispose();this._docs.clear();for(let t of this._streams.values())t.dispose();this._streams.clear(),this._transport.disconnect()}};var Je=new Set(["then","catch","finally","toJSON",Symbol.toPrimitive]);function He(n,e){return new Proxy({},{get(t,r){if(!(Je.has(r)||typeof r!="string"))return s=>{let o=s??{},i=()=>`s_${Date.now()}_${Math.random().toString(36).slice(2)}`,u=i(),h=new B,p=new $({url:"",orgId:e.orgId,jwt:e.jwt,authProvider:e.authProvider,sessionId:u}),d=new D(u,h,p),a=async l=>{let g=await ie({baseUrl:e.baseUrl,fallbackUrls:e.fallbackUrls,app:n,functionName:r,orgId:e.orgId,jwt:e.jwt,getAccessToken:e.getAccessToken,authProvider:e.authProvider,idempotencyKey:l}),f=e.getAccessToken?await e.getAccessToken()??void 0:e.jwt;return d.setSessionId(g.sessionId),{url:g.wsUrl,sessionId:g.sessionId,jwt:f,iceServers:g.response.ice_servers}};return p.setConnectionResolver(()=>a(i())),p.on("connected",()=>{p.multiplexer&&h.setTarget(p.multiplexer)}),(async()=>{let l=await a(u);p.setAuth({jwt:l.jwt,authProvider:e.authProvider,orgId:e.orgId}),p.setConnection({url:l.url,sessionId:l.sessionId,iceServers:l.iceServers}),await p.connect({app:n,functionName:r,args:o})})().catch(l=>{console.error(`[urun] Failed to connect session for ${r}:`,l)}),d}}})}var he=3e4,me="stream:",Q=class{_ws;_multiplexer;_pendingRpc=new Map;_rpcId=0;constructor(e,t){this._ws=e,this._multiplexer=t,this._ws.addEventListener("message",r=>{let s;try{s=JSON.parse(typeof r.data=="string"?r.data:"")}catch{return}if(s.rpcId&&this._pendingRpc.has(s.rpcId)){let o=this._pendingRpc.get(s.rpcId);this._pendingRpc.delete(s.rpcId),clearTimeout(o.timer),s.error?o.reject(new Error(s.error)):o.resolve(s.result)}})}async get(e){return this._sendRpc("store.get",{key:e})}async has(e){return await this._sendRpc("store.has",{key:e})}on(e,t){let r=`${me}${e}`;return this._multiplexer.on(r,s=>{t(s)})}emit(e,t){let r=`${me}${e}`,s=typeof t=="object"&&t!==null&&!Array.isArray(t)?t:{data:t};this._multiplexer.emit(r,s)}_getInternals(){return{multiplexer:this._multiplexer,ws:this._ws}}_sendRpc(e,t){return new Promise((r,s)=>{if(!this._ws||this._ws.readyState!==WebSocket.OPEN){s(new Error("WebSocket not open"));return}let o=String(++this._rpcId),i=setTimeout(()=>{this._pendingRpc.has(o)&&(this._pendingRpc.delete(o),s(new Error(`RPC request "${e}" timed out after ${he}ms`)))},he);this._pendingRpc.set(o,{resolve:r,reject:s,timer:i}),this._ws.send(JSON.stringify({rpcId:o,type:e,...t}))})}};function Ve(n){let r=`${n.baseUrl.replace(/\/$/,"").replace(/^http/,"ws")}/store/${encodeURIComponent(n.orgId)}`,s=new WebSocket(r);(n.jwt||n.apiKey)&&s.addEventListener("open",()=>{s.send(JSON.stringify({type:"auth",orgId:n.orgId,jwt:n.jwt,authProvider:n.authProvider,apiKey:n.apiKey}))});let o=new ne(s);return new Q(s,o)}var ze='video/mp4; codecs="avc1.42E01E"';function Xe(n,e){let t=e?.codec??ze,r=document.createElement("video");r.muted=!0,r.playsInline=!0;let s=new MediaSource,o=URL.createObjectURL(s);r.src=o,s.addEventListener("sourceopen",()=>{let l;try{l=s.addSourceBuffer(t)}catch(_){throw _ instanceof DOMException&&_.name==="NotSupportedError"?new Error(`Codec not supported: "${t}". Ensure the codec string matches the fMP4 container format. Common values: video/mp4; codecs="avc1.42E01E" (H.264 Baseline), video/mp4; codecs="avc1.4D401F" (H.264 Main).`):_}let g=n.getReader();function f(){return l.updating?new Promise(_=>{l.addEventListener("updateend",()=>_(),{once:!0})}):Promise.resolve()}async function w(){try{for(;;){let{done:_,value:S}=await g.read();if(_){await f(),s.readyState==="open"&&s.endOfStream();return}await f();try{l.appendBuffer(S)}catch(m){if(m instanceof DOMException&&m.name==="QuotaExceededError"){let v=l.buffered;if(v.length>0){let R=v.start(v.length-1);l.remove(0,R),await f(),l.appendBuffer(S)}else throw m}else throw m}}}catch{if(s.readyState==="open")try{s.endOfStream("decode")}catch{}}}w()}),r.play().catch(()=>{});let i=r,u=i.captureStream??i.mozCaptureStream;if(!u)throw new Error("captureStream() is not supported in this browser. videoStream() requires HTMLMediaElement.captureStream() support.");let h=u.call(r),p=h.getTracks(),d=0,a=p.length;if(a===0)r.addEventListener("emptied",()=>{URL.revokeObjectURL(o)},{once:!0});else for(let l of p)l.addEventListener("ended",()=>{d++,d>=a&&URL.revokeObjectURL(o)});return h}export{He as App,fe as DEFAULT_DOC_SYNC_TIMEOUT_MS,k as RequestAbortError,M as RequestCancelledError,U as RequestDocSyncError,y as RequestError,O as RequestTimeoutError,D as Session,C as StreamDirectionConflict,Ve as createStore,Xe as videoStream};
@@ -1,4 +1,4 @@
1
- export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, D as DeferredChannelMultiplexer, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './transport-CI8aVD2U.mjs';
1
+ export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, D as DeferredChannelMultiplexer, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './transport-BWNRIdMX.mjs';
2
2
 
3
3
  declare function isNodeRuntime(): boolean;
4
4
 
@@ -1,4 +1,4 @@
1
- export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, D as DeferredChannelMultiplexer, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './transport-CI8aVD2U.js';
1
+ export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, D as DeferredChannelMultiplexer, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './transport-BWNRIdMX.js';
2
2
 
3
3
  declare function isNodeRuntime(): boolean;
4
4
 
@@ -193,6 +193,10 @@ interface SessionStream {
193
193
  on(event: 'track', handler: (track: MediaStreamTrack | null) => void): () => void;
194
194
 
195
195
  messages(): AsyncIterable<unknown>;
196
+
197
+ emit(payload: unknown, options?: {
198
+ to?: string;
199
+ }): Promise<void>;
196
200
  }
197
201
 
198
202
  interface RequestOptions {
@@ -193,6 +193,10 @@ interface SessionStream {
193
193
  on(event: 'track', handler: (track: MediaStreamTrack | null) => void): () => void;
194
194
 
195
195
  messages(): AsyncIterable<unknown>;
196
+
197
+ emit(payload: unknown, options?: {
198
+ to?: string;
199
+ }): Promise<void>;
196
200
  }
197
201
 
198
202
  interface RequestOptions {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@urun-sh/core",
3
- "version": "0.1.41",
3
+ "version": "0.1.42",
4
4
  "description": "Core transport and channel primitives for the urun TypeScript SDK",
5
5
  "repository": {
6
6
  "type": "git",