@urun-sh/core 0.1.46 → 0.1.48

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 B,f as se,i as $}from"./chunk-O7ZS2RQJ.mjs";var Se="session-api.prod.cloud.urun.sh",ve=["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 Ee(n))r(s);return t}var be=120,ke=1e3,Re=3;function Ae(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 Ie(s,n,{pollAttempts:be,retryAfterLimitMs:r?ke: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 Ie(n,e,t){let r,s,o,i=n,c=0,f=new Set;for(let p=0;p<t.pollAttempts;p++){s=o??await Y(e),o=void 0;let l=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(Te(e))});if(!r&&(l.status===307||l.status===308)){let h=Ae(l.headers.get("location"));if(h&&h!==i&&c<Re){c+=1,i=h;continue}throw new Error(`[urun] session create redirected from ${i} without a usable target`)}let a=await ce(l);if(l.ok&&(a.status==="allocated"||!a.status&&!!a.session_id)&&!!a.session_id){let h=a.session_id;if(!a.ws_url)throw new A(`[urun] gateway allocated session ${h} without ws_url`);if(!ue(a.ws_url))throw new A(`[urun] gateway allocated session ${h} with non-absolute ws_url`);return{baseUrl:i,sessionId:h,wsUrl:a.ws_url,response:a}}if(l.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 xe(Pe(l,a,t.retryAfterLimitMs));continue}if((l.status===401||l.status===403)&&e.getAccessToken){let h=s??"";f.add(h);let w=await Y(e,{forceRefresh:!0,reason:"unauthorized"});if(w&&!f.has(w)){o=w,r=void 0;continue}}let g=a.error_message||a.error_code||`HTTP ${l.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 Te(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 c=await ce(i);if(!c.ws_url||!ue(c.ws_url))throw new A(`[urun] viewer-connect returned no usable ws_url for ${n.sessionId}`);return{baseUrl:N(r),sessionId:n.sessionId,wsUrl:c.ws_url,response:c}}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 Pe(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 xe(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 Ee(n){try{return new URL(n).hostname!==Se?[]:ve}catch{return[]}}import*as x from"yjs";var de=Symbol("urun:doc:remote"),Oe=Symbol("urun:doc:local");function I(n){return n!==null&&typeof n=="object"&&!Array.isArray(n)}var F="$bytes";function Ce(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 Me(n){return n instanceof ArrayBuffer?new Uint8Array(n):n}function De(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 qe(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(Ce(n))return{[F]:De(Me(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 qe(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 Le(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 le(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!==de&&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(le(e)),this.notify();return}this.applyPatch(e)}get(e,t){let r=this.snapshot();if(!e)return E(r);let s=Le(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,de),!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):le(s);JSON.stringify(i)!==JSON.stringify(o)&&this._root.set(r,i)}},Oe)}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)}},C=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)}},U=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 je=new Set,Be="rpc",$e="llm",he=3e4,Ne="llm-resp";function Fe(n){return`${Ne}:${n}`}function z(){return se()}function Ke(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 Ge(n,e,t,r,s,o,i,c,f){let p=[],l=null,a=!1,d=null,g=!1,h,w,_=new Promise((u,b)=>{h=u,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(l){if(p.length>0){let u=l;l=null,u.resolve({value:p.shift(),done:!1})}else if(d!==null){let u=l;l=null,u.reject(d)}else if(a){let u=l;l=null,u.resolve({value:void 0,done:!0})}}},we=u=>{a||(p.push(u),G())},T=u=>{a||(d=u,a=!0,w(u),j(),G())},ee=u=>{a||(a=!0,h(u),j(),G())},te=()=>T(new k(e)),_e=u=>{if(!(a||!u||typeof u!="object"))switch(u.t){case"delta":typeof u.delta=="string"&&we(u.delta);break;case"response":ee(u.body);break;case"error":{let{message:b,code:P}=Ke(u.body);T(new y(b,{requestId:e,code:u.code??P}));break}}},ye=()=>{let u=S.messages()[Symbol.asyncIterator]();m=()=>{u.return?.(void 0)};let b=()=>{L&&u.next().then(P=>{if(L){if(P.done){a||ee(void 0);return}_e(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=c?.(u=>T(u))??null,ye(),n.set({requests:{[e]:{payload:t,consumer_id:r,stream:s}}}),f&&f>0&&!n.synced&&(R=setTimeout(()=>{R=null,!a&&!n.synced&&T(new C(f,e))},f),q=n.onSynced(()=>Z()))}};return{deltas:{[Symbol.asyncIterator](){return{next(){if(re(),p.length>0)return Promise.resolve({value:p.shift(),done:!1});if(d!==null){let u=d;return d=null,Promise.reject(u)}return a?Promise.resolve({value:void 0,done:!0}):new Promise((u,b)=>{l={resolve:u,reject:b}})},return(){return a||(a=!0,h(void 0),j()),Promise.resolve({value:void 0,done:!0})},throw(u){return a||(a=!0,w(u),j()),Promise.reject(u)}}}},body:_,start:re}}function We(n,e){return[`streams/${n}/${e}`,`streams/${n}/*`]}function Ye(n,e){return`streams/${n}/${e??"*"}`}function fe(n){if(n&&typeof n=="object"){let{epoch:e,by:t}=n,r={epoch:typeof e=="number"?e:0};return(t==="runtime"||t==="browser")&&(r.by=t),r}}function Je(n,e){let r=n.get("streams")?.[e];if(!r||typeof r!="object")return null;let{kind:s,rt:o,br:i}=r,c={};(s==="audio"||s==="video")&&(c.kind=s);let f=fe(o);f&&(c.rt=f);let p=fe(i);return p&&(c.br=p),c}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(c){if(!s)if(r){let f=r;r=null,f({value:c,done:!1})}else t.push(c)},end(){if(s=!0,r){let c=r;r=null,c({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(c=>{r=c})},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 We(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(e){if(!this._controlDoc)return;let t=this._controlDoc(),r=Je(t,this._name),s=r?.br;if(s?.by==="runtime")throw new U(this._name,"runtime","browser");if(s)return;let o={br:{epoch:1}};r?.rt&&(o.rt=r.rt);let i=r?.kind??e;i&&(o.kind=i),t.set({streams:{[this._name]:o}})}async attach(e){this._claimBrowserProducer("audio"),await this._transport.addTrack(e,this._name)}async attachVideo(e){this._claimBrowserProducer("video"),await this._transport.addVideoTrack(e,this._name)}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=Ye(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}),c=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"}),c}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,je.has(e)?null:this._transport),this._docs.set(e,t)),t}sendImage(e){return this.request({reference_image:{value:e}})}sendImageLegacyDesired(e){this.doc("control").set({desired:{reference_image:{value:e}}})}request(e,t={}){let r=this.doc(Be),s=z();return new Promise((o,i)=>{let c=!1,f=null,p=null,l=null,a=()=>{p&&(clearTimeout(p),p=null),f&&(f(),f=null),l&&(this._activeRequests.delete(l),l=null),t.signal?.removeEventListener("abort",g),r.set({requests:{[s]:null}})},d=w=>{c||(c=!0,a(),w())},g=()=>d(()=>i(new k(s)));if(t.signal){if(t.signal.aborted){c=!0,i(new k(s));return}t.signal.addEventListener("abort",g,{once:!0})}let h=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);d(()=>i(new y(v,{requestId:s,code:m.code})))}else d(()=>o(m.result))};f=r.on("change",h),l=w=>d(()=>i(w)),this._activeRequests.add(l),typeof t.timeout=="number"&&t.timeout>=0&&(p=setTimeout(()=>d(()=>i(new O(t.timeout,s))),t.timeout)),r.set({requests:{[s]:{payload:e}}}),h(r.get())})}_consumeResponse(e,t,r,s,o){let i=this.doc($e);return Ge(i,e,t,this._transport.consumerId,r,()=>this.stream(Fe(e)),s,c=>(this._activeRequests.add(c),()=>this._activeRequests.delete(c)),o??he)}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 He=new Set(["then","catch","finally","toJSON",Symbol.toPrimitive]);function Ve(n,e){return new Proxy({},{get(t,r){if(!(He.has(r)||typeof r!="string"))return s=>{let o=s??{},i=()=>`s_${Date.now()}_${Math.random().toString(36).slice(2)}`,c=i(),f=new B,p=new $({url:"",orgId:e.orgId,jwt:e.jwt,authProvider:e.authProvider,sessionId:c}),l=new D(c,f,p),a=async d=>{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:d}),h=e.getAccessToken?await e.getAccessToken()??void 0:e.jwt;return l.setSessionId(g.sessionId),{url:g.wsUrl,sessionId:g.sessionId,jwt:h,iceServers:g.response.ice_servers}};return p.setConnectionResolver(()=>a(i())),p.on("connected",()=>{p.multiplexer&&f.setTarget(p.multiplexer)}),(async()=>{let d=await a(c);p.setAuth({jwt:d.jwt,authProvider:e.authProvider,orgId:e.orgId}),p.setConnection({url:d.url,sessionId:d.sessionId,iceServers:d.iceServers}),await p.connect({app:n,functionName:r,args:o})})().catch(d=>{console.error(`[urun] Failed to connect session for ${r}:`,d)}),l}}})}var me=3e4,ge="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=`${ge}${e}`;return this._multiplexer.on(r,s=>{t(s)})}emit(e,t){let r=`${ge}${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 ${me}ms`)))},me);this._pendingRpc.set(o,{resolve:r,reject:s,timer:i}),this._ws.send(JSON.stringify({rpcId:o,type:e,...t}))})}};function ze(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 Xe='video/mp4; codecs="avc1.42E01E"';function Qe(n,e){let t=e?.codec??Xe,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 d;try{d=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 h(){return d.updating?new Promise(_=>{d.addEventListener("updateend",()=>_(),{once:!0})}):Promise.resolve()}async function w(){try{for(;;){let{done:_,value:S}=await g.read();if(_){await h(),s.readyState==="open"&&s.endOfStream();return}await h();try{d.appendBuffer(S)}catch(m){if(m instanceof DOMException&&m.name==="QuotaExceededError"){let v=d.buffered;if(v.length>0){let R=v.start(v.length-1);d.remove(0,R),await h(),d.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,c=i.captureStream??i.mozCaptureStream;if(!c)throw new Error("captureStream() is not supported in this browser. videoStream() requires HTMLMediaElement.captureStream() support.");let f=c.call(r),p=f.getTracks(),l=0,a=p.length;if(a===0)r.addEventListener("emptied",()=>{URL.revokeObjectURL(o)},{once:!0});else for(let d of p)d.addEventListener("ended",()=>{l++,l>=a&&URL.revokeObjectURL(o)});return f}export{Ve as App,he as DEFAULT_DOC_SYNC_TIMEOUT_MS,k as RequestAbortError,M as RequestCancelledError,C as RequestDocSyncError,y as RequestError,O as RequestTimeoutError,D as Session,U as StreamDirectionConflict,ze as createStore,Qe as videoStream};
1
+ import{a as se,b as j,f as oe,i as $}from"./chunk-DFVMGNRH.mjs";var be="session-api.prod.cloud.urun.sh",Re=["https://session-api.use2.prod.cloud.urun.sh","https://session-api.usw2.prod.cloud.urun.sh"];function N(n){return n.trim().replace(/\/+$/,"")}function ie(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 Me(n))r(s);return t}var Te=120,Ie=1e3,Ae=3;function xe(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 ae(n){let e=ie(n.baseUrl,n.fallbackUrls),t=null,r=e.length>1;for(let s of e)try{return await Pe(s,n,{pollAttempts:Te,retryAfterLimitMs:r?Ie:void 0})}catch(o){if(t=o instanceof Error?o:new Error(String(o)),t instanceof T)throw t}throw t??new Error("[urun] session allocation failed")}async function Pe(n,e,t){let r,s,o,i=n,a=0,f=new Set;for(let l=0;l<t.pollAttempts;l++){s=o??await Y(e),o=void 0;let u=r?await fetch(`${i}/api/session-requests/${encodeURIComponent(r)}`,{headers:G(e,s)}):await fetch(`${i}/api/sessions/create`,{method:"POST",redirect:"manual",headers:{...G(e,s),"Content-Type":"application/json","Idempotency-Key":e.idempotencyKey},body:JSON.stringify(Ce(e))});if(!r&&(u.status===307||u.status===308)){let h=xe(u.headers.get("location"));if(h&&h!==i&&a<Ae){a+=1,i=h;continue}throw new Error(`[urun] session create redirected from ${i} without a usable target`)}let c=await ue(u);if(u.ok&&(c.status==="allocated"||!c.status&&!!c.session_id)&&!!c.session_id){let h=c.session_id;if(!c.ws_url)throw new T(`[urun] gateway allocated session ${h} without ws_url`);if(!de(c.ws_url))throw new T(`[urun] gateway allocated session ${h} with non-absolute ws_url`);return{baseUrl:i,sessionId:h,wsUrl:c.ws_url,response:c}}if(u.status===202||c.status==="pending"||c.status==="queued"||c.queued){if(r=c.request_id||r,!r)throw new Error("[urun] gateway queued session without request_id");await Oe(Ee(u,c,t.retryAfterLimitMs));continue}if((u.status===401||u.status===403)&&e.getAccessToken){let h=s??"";f.add(h);let g=await Y(e,{forceRefresh:!0,reason:"unauthorized"});if(g&&!f.has(g)){o=g,r=void 0;continue}}let m=c.error_message||c.error_code||`HTTP ${u.status}`;throw new Error(`[urun] session allocation failed at ${i}: ${m}`)}throw new Error(`[urun] timed out waiting for session allocation at ${i}`)}function G(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 Ce(n){return{app:n.app,function:n.functionName,gpus:1,idempotency_key:n.idempotencyKey}}async function ce(n){let e=ie(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:G(s,o)});if(!i.ok)throw new Error(`[urun] viewer-connect for ${n.sessionId} failed: HTTP ${i.status}`);let a=await ue(i);if(!a.ws_url||!de(a.ws_url))throw new T(`[urun] viewer-connect returned no usable ws_url for ${n.sessionId}`);return{baseUrl:N(r),sessionId:n.sessionId,wsUrl:a.ws_url,response:a}}catch(s){if(t=s instanceof Error?s:new Error(String(s)),t instanceof T)throw t}throw t??new Error("[urun] viewer-connect failed")}async function ue(n){try{let e=await n.json();return e&&typeof e=="object"?e:{}}catch{return{}}}function Ee(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 Oe(n){return new Promise(e=>setTimeout(e,n))}var T=class extends Error{};function de(n){try{let e=new URL(n);return e.protocol==="ws:"||e.protocol==="wss:"}catch{return!1}}function Me(n){try{return new URL(n).hostname!==be?[]:Re}catch{return[]}}import*as P from"yjs";var le=Symbol("urun:doc:remote"),Ue=Symbol("urun:doc:local");function I(n){return n!==null&&typeof n=="object"&&!Array.isArray(n)}var F="$bytes";function De(n){return n instanceof Uint8Array||n instanceof ArrayBuffer}function Be(n){if(!I(n))return!1;let e=Object.keys(n);return e.length===1&&e[0]===F&&typeof n[F]=="string"}function qe(n){return n instanceof ArrayBuffer?new Uint8Array(n):n}function Le(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 je(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(De(n))return{[F]:Le(qe(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 C(n){if(Be(n))return je(n[F]);if(Array.isArray(n))return n.map(C);if(I(n)){let e={};for(let[t,r]of Object.entries(n))e[t]=C(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 fe=Symbol("urun:doc:path-absent");function $e(n,e){let t=e.split("."),r=n;for(let s of t){if(r===null||typeof r!="object"||!(s in r))return fe;r=r[s]}return r}function pe(n){return n===void 0?n:JSON.parse(JSON.stringify(n))}var K=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!==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(pe(e)),this.notify();return}this.applyPatch(e)}get(e,t){let r=this.snapshot();if(!e)return C(r);let s=$e(r,e);return s===fe?t:C(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,P.encodeStateAsUpdate(this._doc))}applyRemote(e){if(P.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):pe(s);JSON.stringify(i)!==JSON.stringify(o)&&this._root.set(r,i)}},Ue)}snapshot(){let e=this._root.toJSON();for(let t of this._pendingPatches)e=H(e,t);return e}notify(){let e=C(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 S=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)}},E=class extends S{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)}},O=class extends S{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)}},M=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)}},b=class extends S{constructor(e){super("[urun] request aborted",{requestId:e}),this.name="RequestAbortError",Object.setPrototypeOf(this,new.target.prototype)}},U=class extends S{constructor(e){super("[urun] request cancelled: session disconnected",{requestId:e}),this.name="RequestCancelledError",Object.setPrototypeOf(this,new.target.prototype)}};var he="video/mp4";function z(n,e={}){let t=e.timesliceMs??1e3,r=null,s=null,o=!1,i=(a,f,l)=>{let u=typeof MediaRecorder>"u"?void 0:MediaRecorder;if(!u)throw new Error("[urun] stream.chunks(): MediaRecorder is unavailable in this runtime. Pass { source } to chunks() to inject a byte-tap (e.g. a Node/werift consumer).");let c=e.mimeType??(typeof u.isTypeSupported=="function"&&u.isTypeSupported(he)?he:void 0),p=new MediaStream([a]),m=new u(p,c?{mimeType:c}:void 0);r=m;let h=Promise.resolve();m.ondataavailable=g=>{let y=g.data;o||!y||y.size===0||(h=h.then(async()=>{let _=new Uint8Array(await y.arrayBuffer());o||f(_)}))},m.onstop=()=>{h.then(()=>{o||l()})},m.onerror=()=>{h.then(()=>{o||l()})},m.start(t)};return{start(a,f){if(r||o)return;let l=n.track();if(l){i(l,a,f);return}s=n.onTrack(u=>{!u||r||o||(s?.(),s=null,i(u,a,f))})},stop(){if(o)return;o=!0,s?.(),s=null;let a=r;if(r=null,a&&a.state!=="inactive")try{a.stop()}catch{}}}}function Ne(n){let e=n;return typeof e[Symbol.asyncIterator]=="function"||(e[Symbol.asyncIterator]=function(){let t=n.getReader();return{next(){return t.read()},async return(){try{await t.cancel()}catch{}try{t.releaseLock()}catch{}return{value:void 0,done:!0}},[Symbol.asyncIterator](){return this}}}),e}function me(n,e){let t=null,r=!1,s=!1,o=new ReadableStream({pull(i){r||(r=!0,t=n(e),t.start(a=>{if(!s)try{i.enqueue(a)}catch{}},()=>{if(!s){s=!0;try{i.close()}catch{}}}))},cancel(){s=!0,t?.stop(),t=null}},new CountQueuingStrategy({highWaterMark:0}));return Ne(o)}var Fe=new Set,Ke="rpc",We="llm",ye=3e4,Ge="llm-resp";function Ye(n){return`${Ge}:${n}`}function X(){return oe()}function Je(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 He(n,e,t,r,s,o,i,a,f){let l=[],u=null,c=!1,p=null,m=!1,h,g,y=new Promise((d,k)=>{h=d,g=k});y.catch(()=>{});let _=o(),w=null,v=null,R=null,B=null,q=!0,ee=()=>{R&&(clearTimeout(R),R=null),B&&(B(),B=null)},L=()=>{q=!1,ee(),w?.(),w=null,v?.(),v=null,i?.removeEventListener("abort",re),_.dispose(),m&&n.set({requests:{[e]:null}})},W=()=>{if(u){if(l.length>0){let d=u;u=null,d.resolve({value:l.shift(),done:!1})}else if(p!==null){let d=u;u=null,d.reject(p)}else if(c){let d=u;u=null,d.resolve({value:void 0,done:!0})}}},Se=d=>{c||(l.push(d),W())},A=d=>{c||(p=d,c=!0,g(d),L(),W())},te=d=>{c||(c=!0,h(d),L(),W())},re=()=>A(new b(e)),ve=d=>{if(!(c||!d||typeof d!="object"))switch(d.t){case"delta":typeof d.delta=="string"&&Se(d.delta);break;case"response":te(d.body);break;case"error":{let{message:k,code:x}=Je(d.body);A(new S(k,{requestId:e,code:d.code??x}));break}}},ke=()=>{let d=_.messages()[Symbol.asyncIterator]();w=()=>{d.return?.(void 0)};let k=()=>{q&&d.next().then(x=>{if(q){if(x.done){c||te(void 0);return}ve(x.value),k()}},x=>{q&&A(x)})};k()},ne=()=>{if(!m){if(m=!0,i){if(i.aborted){A(new b(e));return}i.addEventListener("abort",re,{once:!0})}v=a?.(d=>A(d))??null,ke(),n.set({requests:{[e]:{payload:t,consumer_id:r,stream:s}}}),f&&f>0&&!n.synced&&(R=setTimeout(()=>{R=null,!c&&!n.synced&&A(new O(f,e))},f),B=n.onSynced(()=>ee()))}};return{deltas:{[Symbol.asyncIterator](){return{next(){if(ne(),l.length>0)return Promise.resolve({value:l.shift(),done:!1});if(p!==null){let d=p;return p=null,Promise.reject(d)}return c?Promise.resolve({value:void 0,done:!0}):new Promise((d,k)=>{u={resolve:d,reject:k}})},return(){return c||(c=!0,h(void 0),L()),Promise.resolve({value:void 0,done:!0})},throw(d){return c||(c=!0,g(d),L()),Promise.reject(d)}}}},body:y,start:ne}}function Ve(n,e){return[`streams/${n}/${e}`,`streams/${n}/*`]}function ze(n,e){return`streams/${n}/${e??"*"}`}function ge(n){if(n&&typeof n=="object"){let{epoch:e,by:t}=n,r={epoch:typeof e=="number"?e:0};return(t==="runtime"||t==="browser")&&(r.by=t),r}}function Xe(n,e){let r=n.get("streams")?.[e];if(!r||typeof r!="object")return null;let{kind:s,rt:o,br:i}=r,a={};(s==="audio"||s==="video")&&(a.kind=s);let f=ge(o);f&&(a.rt=f);let l=ge(i);return l&&(a.br=l),a}var Q=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(a){if(!s)if(r){let f=r;r=null,f({value:a,done:!1})}else t.push(a)},end(){if(s=!0,r){let a=r;r=null,a({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(a=>{r=a})},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 Ve(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(e){if(!this._controlDoc)return;let t=this._controlDoc(),r=Xe(t,this._name),s=r?.br;if(s?.by==="runtime")throw new M(this._name,"runtime","browser");if(s)return;let o={br:{epoch:1}};r?.rt&&(o.rt=r.rt);let i=r?.kind??e;i&&(o.kind=i),t.set({streams:{[this._name]:o}})}async attach(e){this._claimBrowserProducer("audio"),await this._transport.addTrack(e,this._name)}async attachVideo(e){this._claimBrowserProducer("video"),await this._transport.addVideoTrack(e,this._name)}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=ze(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)}chunks(e={}){let t=e.source??z;return me(t,{track:()=>this.track,onTrack:s=>this.on("track",s)})}onSeeked(e){return this._transport.on("seeked",(t,r)=>{t===this._name&&e(r)})}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 ce({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 $({url:r.wsUrl,orgId:t.orgId,jwt:s,authProvider:t.authProvider,sessionId:e,iceServers:r.response.ice_servers}),a=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"}),a}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 Q(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,Fe.has(e)?null:this._transport),this._docs.set(e,t)),t}sendImage(e){return this.request({reference_image:{value:e}})}sendImageLegacyDesired(e){this.doc("control").set({desired:{reference_image:{value:e}}})}request(e,t={}){let r=this.doc(Ke),s=X();return new Promise((o,i)=>{let a=!1,f=null,l=null,u=null,c=()=>{l&&(clearTimeout(l),l=null),f&&(f(),f=null),u&&(this._activeRequests.delete(u),u=null),t.signal?.removeEventListener("abort",m),r.set({requests:{[s]:null}})},p=g=>{a||(a=!0,c(),g())},m=()=>p(()=>i(new b(s)));if(t.signal){if(t.signal.aborted){a=!0,i(new b(s));return}t.signal.addEventListener("abort",m,{once:!0})}let h=g=>{let _=g.responses?.[s];if(_==null)return;let w=_;if(w.error!==void 0&&w.error!==null){let v=typeof w.error=="string"?w.error:JSON.stringify(w.error);p(()=>i(new S(v,{requestId:s,code:w.code})))}else p(()=>o(w.result))};f=r.on("change",h),u=g=>p(()=>i(g)),this._activeRequests.add(u),typeof t.timeout=="number"&&t.timeout>=0&&(l=setTimeout(()=>p(()=>i(new E(t.timeout,s))),t.timeout)),r.set({requests:{[s]:{payload:e}}}),h(r.get())})}_consumeResponse(e,t,r,s,o){let i=this.doc(We);return He(i,e,t,this._transport.consumerId,r,()=>this.stream(Ye(e)),s,a=>(this._activeRequests.add(a),()=>this._activeRequests.delete(a)),o??ye)}requestStream(e,t={}){let r=X();return this._consumeResponse(r,e,!0,t.signal,t.docSyncTimeout).deltas}complete(e,t={}){let r=X(),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 U)}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 Qe=new Set(["then","catch","finally","toJSON",Symbol.toPrimitive]);function Ze(n,e){return new Proxy({},{get(t,r){if(!(Qe.has(r)||typeof r!="string"))return s=>{let o=s??{},i=()=>`s_${Date.now()}_${Math.random().toString(36).slice(2)}`,a=i(),f=new j,l=new $({url:"",orgId:e.orgId,jwt:e.jwt,authProvider:e.authProvider,sessionId:a}),u=new D(a,f,l),c=async p=>{let m=await ae({baseUrl:e.baseUrl,fallbackUrls:e.fallbackUrls,app:n,functionName:r,orgId:e.orgId,jwt:e.jwt,getAccessToken:e.getAccessToken,authProvider:e.authProvider,idempotencyKey:p}),h=e.getAccessToken?await e.getAccessToken()??void 0:e.jwt;return u.setSessionId(m.sessionId),{url:m.wsUrl,sessionId:m.sessionId,jwt:h,iceServers:m.response.ice_servers}};return l.setConnectionResolver(()=>c(i())),l.on("connected",()=>{l.multiplexer&&f.setTarget(l.multiplexer)}),(async()=>{let p=await c(a);l.setAuth({jwt:p.jwt,authProvider:e.authProvider,orgId:e.orgId}),l.setConnection({url:p.url,sessionId:p.sessionId,iceServers:p.iceServers}),await l.connect({app:n,functionName:r,args:o})})().catch(p=>{console.error(`[urun] Failed to connect session for ${r}:`,p)}),u}}})}var we=3e4,_e="stream:",Z=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=`${_e}${e}`;return this._multiplexer.on(r,s=>{t(s)})}emit(e,t){let r=`${_e}${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 ${we}ms`)))},we);this._pendingRpc.set(o,{resolve:r,reject:s,timer:i}),this._ws.send(JSON.stringify({rpcId:o,type:e,...t}))})}};function et(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 se(s);return new Z(s,o)}var tt='video/mp4; codecs="avc1.42E01E"';function rt(n,e){let t=e?.codec??tt,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 p;try{p=s.addSourceBuffer(t)}catch(y){throw y instanceof DOMException&&y.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).`):y}let m=n.getReader();function h(){return p.updating?new Promise(y=>{p.addEventListener("updateend",()=>y(),{once:!0})}):Promise.resolve()}async function g(){try{for(;;){let{done:y,value:_}=await m.read();if(y){await h(),s.readyState==="open"&&s.endOfStream();return}await h();try{p.appendBuffer(_)}catch(w){if(w instanceof DOMException&&w.name==="QuotaExceededError"){let v=p.buffered;if(v.length>0){let R=v.start(v.length-1);p.remove(0,R),await h(),p.appendBuffer(_)}else throw w}else throw w}}}catch{if(s.readyState==="open")try{s.endOfStream("decode")}catch{}}}g()}),r.play().catch(()=>{});let i=r,a=i.captureStream??i.mozCaptureStream;if(!a)throw new Error("captureStream() is not supported in this browser. videoStream() requires HTMLMediaElement.captureStream() support.");let f=a.call(r),l=f.getTracks(),u=0,c=l.length;if(c===0)r.addEventListener("emptied",()=>{URL.revokeObjectURL(o)},{once:!0});else for(let p of l)p.addEventListener("ended",()=>{u++,u>=c&&URL.revokeObjectURL(o)});return f}export{Ze as App,ye as DEFAULT_DOC_SYNC_TIMEOUT_MS,b as RequestAbortError,U as RequestCancelledError,O as RequestDocSyncError,S as RequestError,E as RequestTimeoutError,D as Session,M as StreamDirectionConflict,et as createStore,z as mediaRecorderChunkSource,rt 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-DwP_VpLT.mjs';
1
+ export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, D as DeferredChannelMultiplexer, r as SessionStartOptions, T as TransportSession, x as TransportSessionOptions, z as decodeDocSyncFrame, B as encodeDocSyncFrame } from './transport-C3iRb9nz.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-DwP_VpLT.js';
1
+ export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, D as DeferredChannelMultiplexer, r as SessionStartOptions, T as TransportSession, x as TransportSessionOptions, z as decodeDocSyncFrame, B as encodeDocSyncFrame } from './transport-C3iRb9nz.js';
2
2
 
3
3
  declare function isNodeRuntime(): boolean;
4
4