@urun-sh/core 0.1.37 → 0.1.38
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/{chunk-FPOLGUA2.mjs → chunk-LBV7WHPF.mjs} +5 -5
- package/dist/index.d.mts +26 -3
- package/dist/index.d.ts +26 -3
- package/dist/index.js +5 -5
- package/dist/index.mjs +1 -1
- package/dist/{internal-B7GoThNN.d.mts → internal-CrXsIQMr.d.mts} +17 -0
- package/dist/{internal-B7GoThNN.d.ts → internal-CrXsIQMr.d.ts} +17 -0
- package/dist/internal.d.mts +1 -1
- package/dist/internal.d.ts +1 -1
- package/dist/internal.js +4 -4
- package/dist/internal.mjs +1 -1
- package/package.json +1 -1
package/dist/index.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as F,b as P,e as O}from"./chunk-FPOLGUA2.mjs";var re="session-api.prod.cloud.urun.sh",ne=["https://session-api.use2.prod.cloud.urun.sh","https://session-api.usw2.prod.cloud.urun.sh"];function U(n){return n.trim().replace(/\/+$/,"")}function G(n,e){let t=[],r=s=>{if(!s)return;let o=U(s);o&&!t.includes(o)&&t.push(o)};r(n);for(let s of e??[])r(s);for(let s of pe(n))r(s);return t}var se=120,oe=1e3,ie=3;function ae(n){if(!n)return null;try{let e=new URL(n),t=e.pathname.replace(/\/api\/sessions\/create\/?$/,"");return U(`${e.origin}${t}`)}catch{return null}}async function J(n){let e=G(n.baseUrl,n.fallbackUrls),t=null,r=e.length>1;for(let s of e)try{return await ce(s,n,{pollAttempts:se,retryAfterLimitMs:r?oe:void 0})}catch(o){if(t=o instanceof Error?o:new Error(String(o)),t instanceof b)throw t}throw t??new Error("[urun] session allocation failed")}async function ce(n,e,t){let r,s,o,i=n,a=0,f=new Set;for(let p=0;p<t.pollAttempts;p++){s=o??await L(e),o=void 0;let d=r?await fetch(`${i}/api/session-requests/${encodeURIComponent(r)}`,{headers:D(e,s)}):await fetch(`${i}/api/sessions/create`,{method:"POST",redirect:"manual",headers:{...D(e,s),"Content-Type":"application/json","Idempotency-Key":e.idempotencyKey},body:JSON.stringify(ue(e))});if(!r&&(d.status===307||d.status===308)){let h=ae(d.headers.get("location"));if(h&&h!==i&&a<ie){a+=1,i=h;continue}throw new Error(`[urun] session create redirected from ${i} without a usable target`)}let c=await H(d);if(d.ok&&(c.status==="allocated"||!c.status&&!!c.session_id)&&!!c.session_id){let h=c.session_id;if(!c.ws_url)throw new b(`[urun] gateway allocated session ${h} without ws_url`);if(!Y(c.ws_url))throw new b(`[urun] gateway allocated session ${h} with non-absolute ws_url`);return{baseUrl:i,sessionId:h,wsUrl:c.ws_url,response:c}}if(d.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 de(le(d,c,t.retryAfterLimitMs));continue}if((d.status===401||d.status===403)&&e.getAccessToken){let h=s??"";f.add(h);let g=await L(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 ${d.status}`;throw new Error(`[urun] session allocation failed at ${i}: ${m}`)}throw new Error(`[urun] timed out waiting for session allocation at ${i}`)}function D(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 L(n,e){return n.getAccessToken?await n.getAccessToken(e)??void 0:n.jwt}function ue(n){return{app:n.app,function:n.functionName,gpus:1,idempotency_key:n.idempotencyKey}}async function K(n){let e=G(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 L(s),i=await fetch(`${U(r)}/api/sessions/${encodeURIComponent(n.sessionId)}/viewer-connect`,{headers:D(s,o)});if(!i.ok)throw new Error(`[urun] viewer-connect for ${n.sessionId} failed: HTTP ${i.status}`);let a=await H(i);if(!a.ws_url||!Y(a.ws_url))throw new b(`[urun] viewer-connect returned no usable ws_url for ${n.sessionId}`);return{baseUrl:U(r),sessionId:n.sessionId,wsUrl:a.ws_url,response:a}}catch(s){if(t=s instanceof Error?s:new Error(String(s)),t instanceof b)throw t}throw t??new Error("[urun] viewer-connect failed")}async function H(n){try{let e=await n.json();return e&&typeof e=="object"?e:{}}catch{return{}}}function le(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 de(n){return new Promise(e=>setTimeout(e,n))}var b=class extends Error{};function Y(n){try{let e=new URL(n);return e.protocol==="ws:"||e.protocol==="wss:"}catch{return!1}}function pe(n){try{return new URL(n).hostname!==re?[]:ne}catch{return[]}}import*as R from"yjs";var V=Symbol("urun:doc:remote"),he=Symbol("urun:doc:local");function M(n){return n!==null&&typeof n=="object"&&!Array.isArray(n)}function j(n,e){let t={...n};for(let r of Object.keys(e)){let s=e[r],o=t[r];M(s)&&M(o)?t[r]=j(o,s):t[r]=s}return t}function fe(n,e){let t=e.split("."),r=n;for(let s of t){if(r==null||typeof r!="object")return;r=r[s]}return r}function W(n){return n===void 0?n:JSON.parse(JSON.stringify(n))}var q=class{_doc=new R.Doc;_root=this._doc.getMap("session");_listeners=new Set;_key;_sessionId;_transport;_transportUnsubs=[];_synced;_pendingPatches=[];_texts=new Map;_observer=()=>this.notify();_updateHandler=(e,t)=>{t!==V&&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}set(e){if(!this._synced){this._pendingPatches.push(W(e)),this.notify();return}this.applyPatch(e)}get(e,t){let r=this.snapshot();return e?fe(r,e)??t:r}on(e,t){return this._listeners.add(t),()=>this._listeners.delete(t)}text(e){let t=this._texts.get(e);return t||(t=new $(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();for(let e of this._texts.values())e.dispose();this._texts.clear(),this._doc.destroy()}sendHello(){this._transport&&this._transport.sendDocSync(this._key,R.encodeStateAsUpdate(this._doc))}applyRemote(e){if(R.applyUpdate(this._doc,e,V),!this._synced){this._synced=!0;let t=this._pendingPatches.splice(0);for(let r of t)this.applyPatch(r)}}applyPatch(e){this._doc.transact(()=>{let t=this._root.toJSON();for(let[r,s]of Object.entries(e)){let o=t[r],i=M(s)&&M(o)?j(o,s):W(s);JSON.stringify(i)!==JSON.stringify(o)&&this._root.set(r,i)}},he)}snapshot(){let e=this._root.toJSON();for(let t of this._pendingPatches)e=j(e,t);return e}notify(){let e=this.snapshot();for(let t of this._listeners)t(e)}},$=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)}},T=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)}},k=class extends y{constructor(e){super("[urun] request aborted",{requestId:e}),this.name="RequestAbortError",Object.setPrototypeOf(this,new.target.prototype)}},x=class extends y{constructor(e){super("[urun] request cancelled: session disconnected",{requestId:e}),this.name="RequestCancelledError",Object.setPrototypeOf(this,new.target.prototype)}};var ge=new Set,z="rpc";function X(){let n=globalThis.crypto;return n?.randomUUID?n.randomUUID():`req_${Date.now().toString(36)}_${Math.random().toString(36).slice(2)}`}function me(n,e,t,r,s){return{[Symbol.asyncIterator](){let o=[],i=null,a=!1,f=null,p=!1,d=n.text(e),c=null,u=null,m=null,h=()=>{c?.(),c=null,u?.(),u=null,m?.(),m=null,r?.removeEventListener("abort",S),p&&n.set({requests:{[e]:null}})},g=()=>{if(i){if(o.length>0){let l=i;i=null,l.resolve({value:o.shift(),done:!1})}else if(f!==null){let l=i;i=null,l.reject(f)}else if(a){let l=i;i=null,l.resolve({value:void 0,done:!0})}}},_=l=>{a||(o.push(l),g())},v=l=>{a||(f=l,a=!0,h(),g())},w=()=>{a||(a=!0,h(),g())},S=()=>v(new k(e)),E=l=>{if(l)if(l.error!==void 0&&l.error!==null){let I=typeof l.error=="string"?l.error:JSON.stringify(l.error);v(new y(I,{requestId:e,code:l.code}))}else l.done&&w()},ee=()=>{if(p)return;if(p=!0,r){if(r.aborted){v(new k(e));return}r.addEventListener("abort",S,{once:!0})}m=s?.(C=>v(C))??null,c=d.on("delta",_),u=n.on("change",C=>{if(a)return;let te=C.responses;E(te?.[e])}),n.set({requests:{[e]:{payload:t,stream:!0}}});let l=d.toString();l.length>0&&o.push(l);let I=n.get();E(I.responses?.[e])};return{next(){if(ee(),o.length>0)return Promise.resolve({value:o.shift(),done:!1});if(f!==null){let l=f;return f=null,Promise.reject(l)}return a?Promise.resolve({value:void 0,done:!0}):new Promise((l,I)=>{i={resolve:l,reject:I}})},return(){return a||(a=!0,h()),Promise.resolve({value:void 0,done:!0})},throw(l){return a||(a=!0,h()),Promise.reject(l)}}}}}var N=class{constructor(e,t){this._name=e;this._transport=t;this._track=this._transport.getTrackByName(this._name)??null,this._unsubscribeTransport=this._transport.on("track",()=>{let r=this._transport.getTrackByName(this._name)??null;r!==this._track&&this._setTrack(r)})}_name;_transport;_track=null;_handlers=new Map;_unsubscribeTransport=null;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 detach(){this._transport.removeTrack()}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._unsubscribeTransport?.(),this._unsubscribeTransport=null,this._handlers.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)}},A=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 K({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 P,i=new O({url:r.wsUrl,orgId:t.orgId,jwt:s,authProvider:t.authProvider,sessionId:e}),a=new n(e,o,i);return i.on("connected",()=>{i.multiplexer&&o.setTarget(i.multiplexer)}),i.setConnection({url:r.wsUrl,sessionId:e}),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 N(e,this._transport),this._streams.set(e,t)),t}doc(e){let t=this._docs.get(e);return t||(t=new q(e,this._sessionId,ge.has(e)?null:this._transport),this._docs.set(e,t)),t}request(e,t={}){let r=this.doc(z),s=X();return new Promise((o,i)=>{let a=!1,f=null,p=null,d=null,c=()=>{p&&(clearTimeout(p),p=null),f&&(f(),f=null),d&&(this._activeRequests.delete(d),d=null),t.signal?.removeEventListener("abort",m),r.set({requests:{[s]:null}})},u=g=>{a||(a=!0,c(),g())},m=()=>u(()=>i(new k(s)));if(t.signal){if(t.signal.aborted){a=!0,i(new k(s));return}t.signal.addEventListener("abort",m,{once:!0})}let h=g=>{let v=g.responses?.[s];if(v==null)return;let w=v;if(w.error!==void 0&&w.error!==null){let S=typeof w.error=="string"?w.error:JSON.stringify(w.error);u(()=>i(new y(S,{requestId:s,code:w.code})))}else u(()=>o(w.result))};f=r.on("change",h),d=g=>u(()=>i(g)),this._activeRequests.add(d),typeof t.timeout=="number"&&t.timeout>=0&&(p=setTimeout(()=>u(()=>i(new T(t.timeout,s))),t.timeout)),r.set({requests:{[s]:{payload:e}}}),h(r.get())})}requestStream(e,t={}){let r=this.doc(z),s=X();return me(r,s,e,t.signal,o=>(this._activeRequests.add(o),()=>this._activeRequests.delete(o)))}disconnect(){let e=Array.from(this._activeRequests);this._activeRequests.clear();for(let t of e)try{t(new x)}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 we=new Set(["then","catch","finally","toJSON",Symbol.toPrimitive]);function _e(n,e){return new Proxy({},{get(t,r){if(!(we.has(r)||typeof r!="string"))return s=>{let o=s??{},i=()=>`s_${Date.now()}_${Math.random().toString(36).slice(2)}`,a=i(),f=new P,p=new O({url:"",orgId:e.orgId,jwt:e.jwt,authProvider:e.authProvider,sessionId:a}),d=new A(a,f,p),c=async u=>{let m=await J({baseUrl:e.baseUrl,fallbackUrls:e.fallbackUrls,app:n,functionName:r,orgId:e.orgId,jwt:e.jwt,getAccessToken:e.getAccessToken,authProvider:e.authProvider,idempotencyKey:u}),h=e.getAccessToken?await e.getAccessToken()??void 0:e.jwt;return d.setSessionId(m.sessionId),{url:m.wsUrl,sessionId:m.sessionId,jwt:h}};return p.setConnectionResolver(()=>c(i())),p.on("connected",()=>{p.multiplexer&&f.setTarget(p.multiplexer)}),(async()=>{let u=await c(a);p.setAuth({jwt:u.jwt,authProvider:e.authProvider,orgId:e.orgId}),p.setConnection({url:u.url,sessionId:u.sessionId}),await p.connect({app:n,functionName:r,args:o})})().catch(u=>{console.error(`[urun] Failed to connect session for ${r}:`,u)}),d}}})}var Q=3e4,Z="stream:",B=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=`${Z}${e}`;return this._multiplexer.on(r,s=>{t(s)})}emit(e,t){let r=`${Z}${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 ${Q}ms`)))},Q);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 F(s);return new B(s,o)}var ye='video/mp4; codecs="avc1.42E01E"';function Se(n,e){let t=e?.codec??ye,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 u;try{u=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 m=n.getReader();function h(){return u.updating?new Promise(_=>{u.addEventListener("updateend",()=>_(),{once:!0})}):Promise.resolve()}async function g(){try{for(;;){let{done:_,value:v}=await m.read();if(_){await h(),s.readyState==="open"&&s.endOfStream();return}await h();try{u.appendBuffer(v)}catch(w){if(w instanceof DOMException&&w.name==="QuotaExceededError"){let S=u.buffered;if(S.length>0){let E=S.start(S.length-1);u.remove(0,E),await h(),u.appendBuffer(v)}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),p=f.getTracks(),d=0,c=p.length;if(c===0)r.addEventListener("emptied",()=>{URL.revokeObjectURL(o)},{once:!0});else for(let u of p)u.addEventListener("ended",()=>{d++,d>=c&&URL.revokeObjectURL(o)});return f}export{_e as App,k as RequestAbortError,x as RequestCancelledError,y as RequestError,T as RequestTimeoutError,A as Session,ve as createStore,Se as videoStream};
|
|
1
|
+
import{a as W,b as U,e as M}from"./chunk-LBV7WHPF.mjs";var ae="session-api.prod.cloud.urun.sh",ce=["https://session-api.use2.prod.cloud.urun.sh","https://session-api.usw2.prod.cloud.urun.sh"];function C(r){return r.trim().replace(/\/+$/,"")}function V(r,e){let t=[],n=s=>{if(!s)return;let o=C(s);o&&!t.includes(o)&&t.push(o)};n(r);for(let s of e??[])n(s);for(let s of we(r))n(s);return t}var ue=120,le=1e3,de=3;function pe(r){if(!r)return null;try{let e=new URL(r),t=e.pathname.replace(/\/api\/sessions\/create\/?$/,"");return C(`${e.origin}${t}`)}catch{return null}}async function z(r){let e=V(r.baseUrl,r.fallbackUrls),t=null,n=e.length>1;for(let s of e)try{return await fe(s,r,{pollAttempts:ue,retryAfterLimitMs:n?le:void 0})}catch(o){if(t=o instanceof Error?o:new Error(String(o)),t instanceof R)throw t}throw t??new Error("[urun] session allocation failed")}async function fe(r,e,t){let n,s,o,i=r,l=0,h=new Set;for(let d=0;d<t.pollAttempts;d++){s=o??await $(e),o=void 0;let a=n?await fetch(`${i}/api/session-requests/${encodeURIComponent(n)}`,{headers:j(e,s)}):await fetch(`${i}/api/sessions/create`,{method:"POST",redirect:"manual",headers:{...j(e,s),"Content-Type":"application/json","Idempotency-Key":e.idempotencyKey},body:JSON.stringify(he(e))});if(!n&&(a.status===307||a.status===308)){let f=pe(a.headers.get("location"));if(f&&f!==i&&l<de){l+=1,i=f;continue}throw new Error(`[urun] session create redirected from ${i} without a usable target`)}let u=await Q(a);if(a.ok&&(u.status==="allocated"||!u.status&&!!u.session_id)&&!!u.session_id){let f=u.session_id;if(!u.ws_url)throw new R(`[urun] gateway allocated session ${f} without ws_url`);if(!Z(u.ws_url))throw new R(`[urun] gateway allocated session ${f} with non-absolute ws_url`);return{baseUrl:i,sessionId:f,wsUrl:u.ws_url,response:u}}if(a.status===202||u.status==="pending"||u.status==="queued"||u.queued){if(n=u.request_id||n,!n)throw new Error("[urun] gateway queued session without request_id");await ge(me(a,u,t.retryAfterLimitMs));continue}if((a.status===401||a.status===403)&&e.getAccessToken){let f=s??"";h.add(f);let w=await $(e,{forceRefresh:!0,reason:"unauthorized"});if(w&&!h.has(w)){o=w,n=void 0;continue}}let g=u.error_message||u.error_code||`HTTP ${a.status}`;throw new Error(`[urun] session allocation failed at ${i}: ${g}`)}throw new Error(`[urun] timed out waiting for session allocation at ${i}`)}function j(r,e){let t={"X-Tenant-Id":r.orgId,"X-Auth-Provider":r.authProvider||"default","X-User-Id":"anonymous"};return e&&(t.Authorization=`Bearer ${e}`),t}async function $(r,e){return r.getAccessToken?await r.getAccessToken(e)??void 0:r.jwt}function he(r){return{app:r.app,function:r.functionName,gpus:1,idempotency_key:r.idempotencyKey}}async function X(r){let e=V(r.baseUrl,r.fallbackUrls),t=null;for(let n of e)try{let s={baseUrl:n,app:"",functionName:"",orgId:r.orgId,jwt:r.jwt,getAccessToken:r.getAccessToken,authProvider:r.authProvider,idempotencyKey:""},o=await $(s),i=await fetch(`${C(n)}/api/sessions/${encodeURIComponent(r.sessionId)}/viewer-connect`,{headers:j(s,o)});if(!i.ok)throw new Error(`[urun] viewer-connect for ${r.sessionId} failed: HTTP ${i.status}`);let l=await Q(i);if(!l.ws_url||!Z(l.ws_url))throw new R(`[urun] viewer-connect returned no usable ws_url for ${r.sessionId}`);return{baseUrl:C(n),sessionId:r.sessionId,wsUrl:l.ws_url,response:l}}catch(s){if(t=s instanceof Error?s:new Error(String(s)),t instanceof R)throw t}throw t??new Error("[urun] viewer-connect failed")}async function Q(r){try{let e=await r.json();return e&&typeof e=="object"?e:{}}catch{return{}}}function me(r,e,t){let n=Number(r.headers.get("Retry-After")||""),s=Number(e.retry_after_seconds??n),o=t??1e4;return Number.isFinite(s)&&s>0?Math.min(s*1e3,o):1e3}function ge(r){return new Promise(e=>setTimeout(e,r))}var R=class extends Error{};function Z(r){try{let e=new URL(r);return e.protocol==="ws:"||e.protocol==="wss:"}catch{return!1}}function we(r){try{return new URL(r).hostname!==ae?[]:ce}catch{return[]}}import*as T from"yjs";var ee=Symbol("urun:doc:remote"),_e=Symbol("urun:doc:local");function q(r){return r!==null&&typeof r=="object"&&!Array.isArray(r)}function N(r,e){let t={...r};for(let n of Object.keys(e)){let s=e[n],o=t[n];q(s)&&q(o)?t[n]=N(o,s):t[n]=s}return t}function ve(r,e){let t=e.split("."),n=r;for(let s of t){if(n==null||typeof n!="object")return;n=n[s]}return n}function te(r){return r===void 0?r:JSON.parse(JSON.stringify(r))}var L=class{_doc=new T.Doc;_root=this._doc.getMap("session");_listeners=new Set;_key;_sessionId;_transport;_transportUnsubs=[];_synced;_pendingPatches=[];_texts=new Map;_observer=()=>this.notify();_updateHandler=(e,t)=>{t!==ee&&this._transport?.sendDocSync(this._key,e)};constructor(e,t,n){this._key=e,this._sessionId=t,this._transport=n??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}set(e){if(!this._synced){this._pendingPatches.push(te(e)),this.notify();return}this.applyPatch(e)}get(e,t){let n=this.snapshot();return e?ve(n,e)??t:n}on(e,t){return this._listeners.add(t),()=>this._listeners.delete(t)}text(e){let t=this._texts.get(e);return t||(t=new B(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();for(let e of this._texts.values())e.dispose();this._texts.clear(),this._doc.destroy()}sendHello(){this._transport&&this._transport.sendDocSync(this._key,T.encodeStateAsUpdate(this._doc))}applyRemote(e){if(T.applyUpdate(this._doc,e,ee),!this._synced){this._synced=!0;let t=this._pendingPatches.splice(0);for(let n of t)this.applyPatch(n)}}applyPatch(e){this._doc.transact(()=>{let t=this._root.toJSON();for(let[n,s]of Object.entries(e)){let o=t[n],i=q(s)&&q(o)?N(o,s):te(s);JSON.stringify(i)!==JSON.stringify(o)&&this._root.set(n,i)}},_e)}snapshot(){let e=this._root.toJSON();for(let t of this._pendingPatches)e=N(e,t);return e}notify(){let e=this.snapshot();for(let t of this._listeners)t(e)}},B=class{constructor(e){this._ytext=e;this._observer=t=>{for(let n of t.delta)if(typeof n.insert=="string"&&n.insert.length>0){let s=n.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)}},x=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)}},k=class extends S{constructor(e){super("[urun] request aborted",{requestId:e}),this.name="RequestAbortError",Object.setPrototypeOf(this,new.target.prototype)}},E=class extends S{constructor(e){super("[urun] request cancelled: session disconnected",{requestId:e}),this.name="RequestCancelledError",Object.setPrototypeOf(this,new.target.prototype)}};var ye=new Set,Se="rpc",be="llm",ke="llm-resp";function Re(r){return`${ke}:${r}`}function F(){let r=globalThis.crypto;return r?.randomUUID?r.randomUUID():`req_${Date.now().toString(36)}_${Math.random().toString(36).slice(2)}`}function Ie(r){if(r&&typeof r=="object"){let e=r.error;if(e&&typeof e=="object"){let{message:t,code:n}=e;return{message:typeof t=="string"?t:JSON.stringify(e),code:typeof n=="string"?n:void 0}}if(typeof e=="string")return{message:e}}return{message:typeof r=="string"?r:JSON.stringify(r)}}function Ae(r,e,t,n,s,o,i,l){let h=[],d=null,a=!1,u=null,p=!1,g,f,w=new Promise((c,b)=>{g=c,f=b});w.catch(()=>{});let _=o(),v=null,m=null,y=!0,I=()=>{y=!1,v?.(),v=null,m?.(),m=null,i?.removeEventListener("abort",Y),_.dispose(),p&&r.set({requests:{[e]:null}})},D=()=>{if(d){if(h.length>0){let c=d;d=null,c.resolve({value:h.shift(),done:!1})}else if(u!==null){let c=d;d=null,c.reject(u)}else if(a){let c=d;d=null,c.resolve({value:void 0,done:!0})}}},re=c=>{a||(h.push(c),D())},P=c=>{a||(u=c,a=!0,f(c),I(),D())},G=c=>{a||(a=!0,g(c),I(),D())},Y=()=>P(new k(e)),oe=c=>{if(!(a||!c||typeof c!="object"))switch(c.t){case"delta":typeof c.delta=="string"&&re(c.delta);break;case"response":G(c.body);break;case"error":{let{message:b,code:A}=Ie(c.body);P(new S(b,{requestId:e,code:c.code??A}));break}}},ie=()=>{let c=_.messages()[Symbol.asyncIterator]();v=()=>{c.return?.(void 0)};let b=()=>{y&&c.next().then(A=>{if(y){if(A.done){a||G(void 0);return}oe(A.value),b()}},A=>{y&&P(A)})};b()},H=()=>{if(!p){if(p=!0,i){if(i.aborted){P(new k(e));return}i.addEventListener("abort",Y,{once:!0})}m=l?.(c=>P(c))??null,ie(),r.set({requests:{[e]:{payload:t,consumer_id:n,stream:s}}})}};return{deltas:{[Symbol.asyncIterator](){return{next(){if(H(),h.length>0)return Promise.resolve({value:h.shift(),done:!1});if(u!==null){let c=u;return u=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,g(void 0),I()),Promise.resolve({value:void 0,done:!0})},throw(c){return a||(a=!0,f(c),I()),Promise.reject(c)}}}},body:w,start:H}}function Te(r,e){return[`streams/${r}/${e}`,`streams/${r}/*`]}var K=class{constructor(e,t,n){this._name=e;this._transport=t;this._laneDoc=n;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;_disposed=!1;messages(){this._ensureSubscribed();let e=this;return{[Symbol.asyncIterator](){let t=[],n=null,s=!1,o={push(l){if(!s)if(n){let h=n;n=null,h({value:l,done:!1})}else t.push(l)},end(){if(s=!0,n){let l=n;n=null,l({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(l=>{n=l})},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 Te(this._name,this._transport.consumerId)){let t=this._laneDoc(e);this._laneSeen.set(e,0);let n=s=>this._drainLane(e,s);n(t.get()),this._laneUnsubs.push(t.on("change",n))}}_drainLane(e,t){let n=t.messages;if(!Array.isArray(n))return;let s=this._laneSeen.get(e)??0;for(;s<n.length;s++){let o=n[s];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 detach(){this._transport.removeTrack()}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 n=this._handlers.get(e);return n||(n=new Set,this._handlers.set(e,n)),n.add(t),()=>{n?.delete(t),n?.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 n of t)n(e)}},O=class r{_sessionId;_multiplexer;_transport;_docs=new Map;_streams=new Map;_activeRequests=new Set;constructor(e,t,n){this._sessionId=e,this._multiplexer=t,this._transport=n,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 n=await X({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 U,i=new M({url:n.wsUrl,orgId:t.orgId,jwt:s,authProvider:t.authProvider,sessionId:e}),l=new r(e,o,i);return i.on("connected",()=>{i.multiplexer&&o.setTarget(i.multiplexer)}),i.setConnection({url:n.wsUrl,sessionId:e}),await i.connect({role:"viewer"}),l}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 n of this._docs.values())n.setSessionId(e)}stream(e){let t=this._streams.get(e);return t||(t=new K(e,this._transport,n=>this.doc(n)),this._streams.set(e,t)),t}doc(e){let t=this._docs.get(e);return t||(t=new L(e,this._sessionId,ye.has(e)?null:this._transport),this._docs.set(e,t)),t}request(e,t={}){let n=this.doc(Se),s=F();return new Promise((o,i)=>{let l=!1,h=null,d=null,a=null,u=()=>{d&&(clearTimeout(d),d=null),h&&(h(),h=null),a&&(this._activeRequests.delete(a),a=null),t.signal?.removeEventListener("abort",g),n.set({requests:{[s]:null}})},p=w=>{l||(l=!0,u(),w())},g=()=>p(()=>i(new k(s)));if(t.signal){if(t.signal.aborted){l=!0,i(new k(s));return}t.signal.addEventListener("abort",g,{once:!0})}let f=w=>{let v=w.responses?.[s];if(v==null)return;let m=v;if(m.error!==void 0&&m.error!==null){let y=typeof m.error=="string"?m.error:JSON.stringify(m.error);p(()=>i(new S(y,{requestId:s,code:m.code})))}else p(()=>o(m.result))};h=n.on("change",f),a=w=>p(()=>i(w)),this._activeRequests.add(a),typeof t.timeout=="number"&&t.timeout>=0&&(d=setTimeout(()=>p(()=>i(new x(t.timeout,s))),t.timeout)),n.set({requests:{[s]:{payload:e}}}),f(n.get())})}_consumeResponse(e,t,n,s){let o=this.doc(be);return Ae(o,e,t,this._transport.consumerId,n,()=>this.stream(Re(e)),s,i=>(this._activeRequests.add(i),()=>this._activeRequests.delete(i)))}requestStream(e,t={}){let n=F();return this._consumeResponse(n,e,!0,t.signal).deltas}complete(e,t={}){let n=F(),s=this._consumeResponse(n,e,!1,t.signal);return s.start(),s.body}disconnect(){let e=Array.from(this._activeRequests);this._activeRequests.clear();for(let t of e)try{t(new E)}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 Pe=new Set(["then","catch","finally","toJSON",Symbol.toPrimitive]);function xe(r,e){return new Proxy({},{get(t,n){if(!(Pe.has(n)||typeof n!="string"))return s=>{let o=s??{},i=()=>`s_${Date.now()}_${Math.random().toString(36).slice(2)}`,l=i(),h=new U,d=new M({url:"",orgId:e.orgId,jwt:e.jwt,authProvider:e.authProvider,sessionId:l}),a=new O(l,h,d),u=async p=>{let g=await z({baseUrl:e.baseUrl,fallbackUrls:e.fallbackUrls,app:r,functionName:n,orgId:e.orgId,jwt:e.jwt,getAccessToken:e.getAccessToken,authProvider:e.authProvider,idempotencyKey:p}),f=e.getAccessToken?await e.getAccessToken()??void 0:e.jwt;return a.setSessionId(g.sessionId),{url:g.wsUrl,sessionId:g.sessionId,jwt:f}};return d.setConnectionResolver(()=>u(i())),d.on("connected",()=>{d.multiplexer&&h.setTarget(d.multiplexer)}),(async()=>{let p=await u(l);d.setAuth({jwt:p.jwt,authProvider:e.authProvider,orgId:e.orgId}),d.setConnection({url:p.url,sessionId:p.sessionId}),await d.connect({app:r,functionName:n,args:o})})().catch(p=>{console.error(`[urun] Failed to connect session for ${n}:`,p)}),a}}})}var ne=3e4,se="stream:",J=class{_ws;_multiplexer;_pendingRpc=new Map;_rpcId=0;constructor(e,t){this._ws=e,this._multiplexer=t,this._ws.addEventListener("message",n=>{let s;try{s=JSON.parse(typeof n.data=="string"?n.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 n=`${se}${e}`;return this._multiplexer.on(n,s=>{t(s)})}emit(e,t){let n=`${se}${e}`,s=typeof t=="object"&&t!==null&&!Array.isArray(t)?t:{data:t};this._multiplexer.emit(n,s)}_getInternals(){return{multiplexer:this._multiplexer,ws:this._ws}}_sendRpc(e,t){return new Promise((n,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 ${ne}ms`)))},ne);this._pendingRpc.set(o,{resolve:n,reject:s,timer:i}),this._ws.send(JSON.stringify({rpcId:o,type:e,...t}))})}};function Ee(r){let n=`${r.baseUrl.replace(/\/$/,"").replace(/^http/,"ws")}/store/${encodeURIComponent(r.orgId)}`,s=new WebSocket(n);(r.jwt||r.apiKey)&&s.addEventListener("open",()=>{s.send(JSON.stringify({type:"auth",orgId:r.orgId,jwt:r.jwt,authProvider:r.authProvider,apiKey:r.apiKey}))});let o=new W(s);return new J(s,o)}var Oe='video/mp4; codecs="avc1.42E01E"';function Ue(r,e){let t=e?.codec??Oe,n=document.createElement("video");n.muted=!0,n.playsInline=!0;let s=new MediaSource,o=URL.createObjectURL(s);n.src=o,s.addEventListener("sourceopen",()=>{let p;try{p=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=r.getReader();function f(){return p.updating?new Promise(_=>{p.addEventListener("updateend",()=>_(),{once:!0})}):Promise.resolve()}async function w(){try{for(;;){let{done:_,value:v}=await g.read();if(_){await f(),s.readyState==="open"&&s.endOfStream();return}await f();try{p.appendBuffer(v)}catch(m){if(m instanceof DOMException&&m.name==="QuotaExceededError"){let y=p.buffered;if(y.length>0){let I=y.start(y.length-1);p.remove(0,I),await f(),p.appendBuffer(v)}else throw m}else throw m}}}catch{if(s.readyState==="open")try{s.endOfStream("decode")}catch{}}}w()}),n.play().catch(()=>{});let i=n,l=i.captureStream??i.mozCaptureStream;if(!l)throw new Error("captureStream() is not supported in this browser. videoStream() requires HTMLMediaElement.captureStream() support.");let h=l.call(n),d=h.getTracks(),a=0,u=d.length;if(u===0)n.addEventListener("emptied",()=>{URL.revokeObjectURL(o)},{once:!0});else for(let p of d)p.addEventListener("ended",()=>{a++,a>=u&&URL.revokeObjectURL(o)});return h}export{xe as App,k as RequestAbortError,E as RequestCancelledError,S as RequestError,x as RequestTimeoutError,O as Session,Ee as createStore,Ue as videoStream};
|
|
@@ -181,6 +181,8 @@ interface SessionStream {
|
|
|
181
181
|
seek(target: number | 'live'): Promise<void>;
|
|
182
182
|
|
|
183
183
|
on(event: 'track', handler: (track: MediaStreamTrack | null) => void): () => void;
|
|
184
|
+
|
|
185
|
+
messages(): AsyncIterable<unknown>;
|
|
184
186
|
}
|
|
185
187
|
|
|
186
188
|
interface RequestOptions {
|
|
@@ -209,6 +211,8 @@ interface Session {
|
|
|
209
211
|
|
|
210
212
|
requestStream(payload: unknown, options?: RequestStreamOptions): AsyncIterable<string>;
|
|
211
213
|
|
|
214
|
+
complete(payload: unknown, options?: RequestStreamOptions): Promise<unknown>;
|
|
215
|
+
|
|
212
216
|
onPhase(handler: (phase: SessionPhase) => void): () => void;
|
|
213
217
|
|
|
214
218
|
disconnect(): void;
|
|
@@ -360,6 +364,12 @@ declare class TransportSession {
|
|
|
360
364
|
private _mediaDeathHandled;
|
|
361
365
|
|
|
362
366
|
private _currentEpoch;
|
|
367
|
+
|
|
368
|
+
private _consumerId;
|
|
369
|
+
|
|
370
|
+
private _pendingStreamSubscribes;
|
|
371
|
+
|
|
372
|
+
get consumerId(): string;
|
|
363
373
|
get state(): TransportState;
|
|
364
374
|
|
|
365
375
|
get currentIncarnation(): number;
|
|
@@ -398,6 +408,13 @@ declare class TransportSession {
|
|
|
398
408
|
removeTrack(): void;
|
|
399
409
|
requestDiagnostics(): void;
|
|
400
410
|
seekStream(name: string, target: number | 'live'): void;
|
|
411
|
+
|
|
412
|
+
subscribeStream(name: string): void;
|
|
413
|
+
|
|
414
|
+
unsubscribeStream(name: string): void;
|
|
415
|
+
private _sendStreamSubscribe;
|
|
416
|
+
|
|
417
|
+
private _flushStreamSubscribes;
|
|
401
418
|
private _handleMessage;
|
|
402
419
|
|
|
403
420
|
private _onStatus;
|
|
@@ -181,6 +181,8 @@ interface SessionStream {
|
|
|
181
181
|
seek(target: number | 'live'): Promise<void>;
|
|
182
182
|
|
|
183
183
|
on(event: 'track', handler: (track: MediaStreamTrack | null) => void): () => void;
|
|
184
|
+
|
|
185
|
+
messages(): AsyncIterable<unknown>;
|
|
184
186
|
}
|
|
185
187
|
|
|
186
188
|
interface RequestOptions {
|
|
@@ -209,6 +211,8 @@ interface Session {
|
|
|
209
211
|
|
|
210
212
|
requestStream(payload: unknown, options?: RequestStreamOptions): AsyncIterable<string>;
|
|
211
213
|
|
|
214
|
+
complete(payload: unknown, options?: RequestStreamOptions): Promise<unknown>;
|
|
215
|
+
|
|
212
216
|
onPhase(handler: (phase: SessionPhase) => void): () => void;
|
|
213
217
|
|
|
214
218
|
disconnect(): void;
|
|
@@ -360,6 +364,12 @@ declare class TransportSession {
|
|
|
360
364
|
private _mediaDeathHandled;
|
|
361
365
|
|
|
362
366
|
private _currentEpoch;
|
|
367
|
+
|
|
368
|
+
private _consumerId;
|
|
369
|
+
|
|
370
|
+
private _pendingStreamSubscribes;
|
|
371
|
+
|
|
372
|
+
get consumerId(): string;
|
|
363
373
|
get state(): TransportState;
|
|
364
374
|
|
|
365
375
|
get currentIncarnation(): number;
|
|
@@ -398,6 +408,13 @@ declare class TransportSession {
|
|
|
398
408
|
removeTrack(): void;
|
|
399
409
|
requestDiagnostics(): void;
|
|
400
410
|
seekStream(name: string, target: number | 'live'): void;
|
|
411
|
+
|
|
412
|
+
subscribeStream(name: string): void;
|
|
413
|
+
|
|
414
|
+
unsubscribeStream(name: string): void;
|
|
415
|
+
private _sendStreamSubscribe;
|
|
416
|
+
|
|
417
|
+
private _flushStreamSubscribes;
|
|
401
418
|
private _handleMessage;
|
|
402
419
|
|
|
403
420
|
private _onStatus;
|
package/dist/internal.d.mts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './internal-
|
|
1
|
+
export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './internal-CrXsIQMr.mjs';
|
package/dist/internal.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './internal-
|
|
1
|
+
export { c as ChannelMessage, d as ChannelMultiplexer, e as ChannelName, n as SessionStartOptions, T as TransportSession, s as TransportSessionOptions, u as decodeDocSyncFrame, v as encodeDocSyncFrame } from './internal-CrXsIQMr.js';
|