@4players/odin-common 8.3.0 → 9.0.0
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/cjs/mod.js +1 -1
- package/esm/mod.js +1 -1
- package/package.json +1 -1
- package/utility/log.d.ts +47 -66
package/cjs/mod.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var Se=Object.create;var M=Object.defineProperty;var ze=Object.getOwnPropertyDescriptor;var ke=Object.getOwnPropertyNames;var Le=Object.getPrototypeOf,Pe=Object.prototype.hasOwnProperty;var Re=(t,e)=>{for(var r in e)M(t,r,{get:e[r],enumerable:!0})},Q=(t,e,r,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let u of ke(e))!Pe.call(t,u)&&u!==r&&M(t,u,{get:()=>e[u],enumerable:!(s=ze(e,u))||s.enumerable});return t};var R=(t,e,r)=>(r=t!=null?Se(Le(t)):{},Q(e||!t||!t.__esModule?M(r,"default",{value:t,enumerable:!0}):r,t)),we=t=>Q(M({},"__esModule",{value:!0}),t);var ht={};Re(ht,{APM_DEFAULTS:()=>Tt,Backend:()=>le,ByteArraySchema:()=>y,CONNECTION_STATS_INITIAL:()=>xt,ChannelSet:()=>D,ChannelSetSchema:()=>q,DEFAULT_FORMATTER:()=>de,JITTER_STATS_INITIAL:()=>bt,JsonSchema:()=>_,LogFunctions:()=>pe,LogHandler:()=>$,LogLevelNames:()=>se,LogLevels:()=>G,LogSymbols:()=>ce,LogVerbosity:()=>C,Logger:()=>H,MainCommandsRpc:()=>je,MainNotificationSchema:()=>Me,MainNotificationsRpc:()=>Ne,MediaAudioPropertiesSchema:()=>te,MediaIdSchema:()=>h,MediaPropertiesSchema:()=>N,MediaSchema:()=>U,MediaVideoPropertiesSchema:()=>re,MessagePackRpcSchema:()=>_e,MessageReceivedSchema:()=>V,MinDBFS:()=>br,PRETTY_FORMATTER:()=>yt,PeerIdSchema:()=>v,PeerPositionSchema:()=>j,PeerSchema:()=>I,PeerUpdateSchema:()=>O,RoomCommandsRpc:()=>Fe,RoomNotificationSchema:()=>Ue,RoomNotificationsRpc:()=>Ie,RoomV1:()=>z,RoomV2:()=>oe,Selector:()=>K,Strand:()=>Y,TokenAudienceSchema:()=>X,TokenClaimsSchema:()=>Ae,TokenSubjectSchema:()=>ee,VAD_DEFAULTS:()=>vt,VideoCodec:()=>Z,WebRtcUpdateSchema:()=>w,abortableSleep:()=>Ye,assert:()=>F,debug:()=>gt,error:()=>lt,extendUrl:()=>et,fail:()=>W,failure:()=>x,find:()=>Je,fromBase64:()=>Oe,fromBase64Url:()=>Ee,fromBytes:()=>Ve,generateUUID:()=>rt,getLevelByName:()=>P,getLevelName:()=>L,getLogger:()=>k,info:()=>ft,isAudioCapable:()=>Ge,isBlinkBrowser:()=>ae,isElectronBrowser:()=>$e,isFailure:()=>ut,isFirefoxBrowser:()=>qe,isFunction:()=>it,isNull:()=>at,isNumber:()=>J,isObject:()=>st,isProperty:()=>ot,isSafariBrowser:()=>We,isSharedArrayBufferCapable:()=>He,isString:()=>ct,isSuccess:()=>dt,isUndefined:()=>pt,nextTick:()=>Qe,normalizeUrl:()=>Xe,oneOrMany:()=>A,sleep:()=>Ke,success:()=>f,toBytes:()=>De,toRaw:()=>Ze,unwrap:()=>b,unwrapOr:()=>B,validateUUID:()=>nt,warn:()=>mt});module.exports=we(ht);var d=require("zod"),y=d.z.custom(t=>t instanceof Uint8Array),Ce=d.z.union([d.z.string(),d.z.number(),d.z.boolean(),d.z.null()]),_=d.z.lazy(()=>d.z.union([Ce,d.z.array(_),d.z.record(_)])),_e=d.z.union([d.z.tuple([d.z.literal(0),d.z.number(),d.z.string(),d.z.unknown()]),d.z.tuple([d.z.literal(1),d.z.number(),d.z.nullable(d.z.string()),d.z.unknown()]),d.z.tuple([d.z.literal(2),d.z.string(),d.z.unknown()])]);var c=require("zod"),X=c.z.enum(["sfu","gateway"]),ee=c.z.enum(["connect","roomclose","roomupdate","roombanclient","roomsendmessage"]),Ae=c.z.object({uid:c.z.string(),cid:c.z.optional(c.z.string()),rid:A(c.z.string()).refine(t=>t.length>=1,{message:"missing rid"}),nsp:c.z.optional(c.z.string()),adr:c.z.optional(c.z.string()),aud:c.z.optional(A(X)),sub:c.z.optional(A(ee)),exp:c.z.optional(c.z.number()),nbf:c.z.optional(c.z.number()),ups:c.z.optional(c.z.string()),tgs:c.z.optional(A(c.z.string())),tsp:c.z.optional(c.z.number()),internal:c.z.optional(c.z.object({server:c.z.optional(c.z.string())}))});function A(t){return c.z.union([t.transform(e=>[e]),c.z.array(t)])}var n=R(require("zod"));var p=R(require("zod")),h=p.number(),te=p.object({kind:p.optional(p.literal("audio")),uid:p.optional(p.string()),customType:p.optional(p.string())}),re=p.object({kind:p.optional(p.literal("video")),codec:p.optional(p.string()),uid:p.optional(p.string()),customType:p.optional(p.string()),id:p.optional(p.string())}),N=p.union([te,re]),U=p.object({id:h,properties:N,paused:p.boolean()});var l=R(require("zod"));var v=l.number(),j=l.union([l.tuple([l.number(),l.number(),l.number()]),l.tuple([l.number(),l.number()])]),I=l.object({id:v,user_id:l.string(),user_data:y,medias:l.array(U)}),O=l.discriminatedUnion("kind",[l.object({kind:l.literal("UserDataChanged"),peer_id:v,user_data:y}),l.object({kind:l.literal("MediaStarted"),peer_id:v,media:U}),l.object({kind:l.literal("MediaStopped"),peer_id:v,media_id:h})]);var ne=R(require("zod")),D=class t{constructor(e=BigInt(0)){this.value=e}from(...e){let r=e.reduce((s,u)=>s|E(u),BigInt(0));return new t(r)}contains(e){return(this.value&E(e))!==BigInt(0)}insert(e){this.value|=E(e)}remove(e){this.value&=~E(e)}[Symbol.iterator](){let e=-1,r=new t(this.value);return{next(){for(;e<63;)if(e+=1,r.contains(e))return{value:e,done:!1};return{value:void 0,done:!0}}}}},q=ne.bigint().transform(t=>new D(t));function E(t){return BigInt(1)<<BigInt(t)}var z;(m=>(m.RoomIdSchema=n.string(),m.RoomSchema=n.object({id:m.RoomIdSchema,customer:n.string(),user_data:y,peers:n.array(I)}),m.RoomUpdateSchema=n.discriminatedUnion("kind",[n.object({kind:n.literal("Joined"),room:m.RoomSchema,media_ids:n.array(h),own_peer_id:v}),n.object({kind:n.literal("Left"),reason:n.enum(["RoomClosing","ServerClosing","PeerKicked"])}),n.object({kind:n.literal("UserDataChanged"),user_data:n.optional(y)}),n.object({kind:n.literal("PeerJoined"),peer:I}),n.object({kind:n.literal("PeerLeft"),peer_id:v})]),m.RoomUpdatesSchema=n.object({updates:n.array(m.RoomUpdateSchema)}),m.RoomStatusSchema=n.enum(["Joining","Joined","Closed"]),m.RoomStatusChangedSchema=n.object({status:m.RoomStatusSchema,message:n.optional(n.string())})))(z||={});var oe;(i=>(i.ParametersSchema=n.record(_),i.PeerProperties=n.object({user_data:y.optional(),tags:n.array(n.string()).optional(),audio_parameters:i.ParametersSchema.optional(),video_parameters:i.ParametersSchema.optional()}),i.PingSchema=n.object({Ping:n.object({id:n.number()})}),i.ChangeSelfSchema=n.object({ChangeSelf:i.PeerProperties.omit({tags:!0})}),i.SetAudioMaskSchema=n.object({SetAudioMask:n.object({peer_id:n.number(),mask:q})}),i.SendMessageSchema=n.object({SendMessage:n.object({peer_ids:n.number().array().default([]),message:y})}),i.CallSchema=i.PingSchema.or(i.ChangeSelfSchema).or(i.SetAudioMaskSchema).or(i.SendMessageSchema),i.PongSchema=n.object({Pong:n.object({id:n.number()})}),i.JoinedSchema=n.object({Joined:n.object({own_peer_id:n.number(),room_id:n.string(),customer:n.string()})}),i.LeftSchema=n.object({Left:n.object({reason:n.enum(["room_closing","server_closing","peer_kicked"])})}),i.PeerJoinedSchema=n.object({PeerJoined:i.PeerProperties.extend({peer_id:n.number(),user_id:n.string()})}),i.PeerLeftSchema=n.object({PeerLeft:n.object({peer_id:n.number()})}),i.PeerChangedSchema=n.object({PeerChanged:i.PeerProperties.extend({peer_id:n.number()})}),i.NewReconnectTokenSchema=n.object({NewReconnectToken:n.object({token:n.string()})}),i.MessageReceivedSchema=n.object({MessageReceived:n.object({sender_peer_id:n.number(),message:y})}),i.ErrorSchema=n.object({Error:n.object({message:y})}),i.EventSchema=i.PongSchema.or(i.JoinedSchema).or(i.LeftSchema).or(i.PeerJoinedSchema).or(i.PeerLeftSchema).or(i.PeerChangedSchema).or(i.NewReconnectTokenSchema).or(i.MessageReceivedSchema).or(i.ErrorSchema)))(oe||={});var ie=require("zod");var V=ie.z.object({sender_peer_id:v,message:y});var a=R(require("zod"));var w=a.discriminatedUnion("kind",[a.object({kind:a.literal("Sdp"),type:a.enum(["Answer","Offer"]),sdp:a.string(),media_map:a.array(a.tuple([h,a.string()]))}),a.object({kind:a.literal("Trickle"),candidate:a.string(),spd_mid:a.optional(a.string()),spd_mline_index:a.optional(a.number()),username_fragment:a.optional(a.union([a.string(),a.null()]))}),a.object({kind:a.literal("TrickleFinished")})]);var o=require("zod");var je={Hello:{request:o.z.object({stream:o.z.literal("main")}),response:o.z.null()},JoinRoom:{request:o.z.object({token:o.z.string(),room_id:z.RoomIdSchema,user_data:y,position:j}),response:o.z.object({peer_id:v,stream_id:o.z.optional(o.z.number()),token:o.z.optional(o.z.string())})},WebRtcUpdate:{request:w,response:o.z.null()},RequestReconnectToken:{request:o.z.object({peer_id:o.z.optional(v)}),response:o.z.string()},Ping:{request:o.z.object({}),response:o.z.null()}},Fe={Hello:{request:o.z.object({stream:o.z.literal("room"),token:o.z.string(),room_id:o.z.string(),user_data:y,position:j}),response:o.z.null()},UpdatePeer:{request:o.z.object({user_data:y}),response:o.z.null()},StartMedia:{request:o.z.object({media_id:h,properties:N}),response:o.z.null()},StopMedia:{request:o.z.object({media_id:h}),response:o.z.null()},PauseMedia:{request:o.z.object({media_id:h}),response:o.z.null()},ResumeMedia:{request:o.z.object({media_id:h}),response:o.z.null()},SetPeerPosition:{request:o.z.object({position:j}),response:o.z.null()},SendMessage:{request:o.z.object({target_peer_ids:o.z.optional(o.z.array(v)),message:y}),response:o.z.null()}};var T=R(require("zod"));var Me=T.object({name:T.literal("WebRtcUpdate"),properties:w}),Ne={WebRtcUpdate:w},Ue=T.union([T.object({name:T.literal("RoomStatusChanged"),properties:z.RoomStatusChangedSchema}),T.object({name:T.literal("RoomUpdated"),properties:z.RoomUpdatesSchema}),T.object({name:T.literal("PeerUpdated"),properties:O}),T.object({name:T.literal("MessageReceived"),properties:V})]),Ie={RoomStatusChanged:z.RoomStatusChangedSchema,RoomUpdated:z.RoomUpdatesSchema,PeerUpdated:O,MessageReceived:V};function F(t,e){t||W(e)}function W(t){throw new Error(t)}function f(t){return{type:"Success",value:t}}function x(t){return{type:"Failure",reason:t}}function b(t){return t.type==="Failure"&&W(t.reason),t.value}function B(t,e){return t.type==="Success"?t.value:e}function Oe(t){try{let e=atob(t),r=Uint8Array.from(e,u=>u.codePointAt(0)),s=new TextDecoder("utf8");return f(s.decode(r))}catch(e){return x(String(e))}}function Ee(t){try{let e=atob(t.replace(/-/g,"+").replace(/_/g,"/")),r=Uint8Array.from(e,u=>u.codePointAt(0)),s=new TextDecoder("utf8");return f(s.decode(r))}catch(e){return x(String(e))}}function De(t){try{F(t!==void 0,"undefined cannot be converted to byte array"),F(t!==null,"null cannot be converted to byte array");let e=JSON.stringify(t),r=new TextEncoder;return f(r.encode(e))}catch(e){return x(String(e))}}function Ve(t){try{F(t.length>0,"empty byte array cannot be converted to value");let e=new TextDecoder().decode(t),r=JSON.parse(e);return f(r)}catch(e){return x(String(e))}}var Be=["VP8","VP9","AV1","H264"],Z=class{constructor(e){this.codec=e}channels=0;clockRate=9e4;isValid(){return Be.includes(this.codec)}isSupported(){if(typeof RTCRtpReceiver>"u"||typeof RTCRtpReceiver.getCapabilities>"u")return null;let e=B(this.getMimeType(),"").toLowerCase(),r=new Set(B(this.getSdpFmtpLine(),"").split(";").map(s=>s.trim().toLowerCase()));return RTCRtpReceiver.getCapabilities("video")?.codecs?.find(s=>{let u=s.mimeType.toLowerCase(),g=new Set((s.sdpFmtpLine??"").split(";").map(m=>m.trim().toLowerCase()));if(e!==u||r.size!==g.size)return!1;for(let m of r)if(!g.has(m))return!1;return!0})??null}getPayloadType(){switch(this.codec){case"VP8":return f(96);case"VP9":return f(98);case"AV1":return f(41);case"H264":return f(102);default:return x("invalid video codec")}}getMimeType(){switch(this.codec){case"VP8":return f("video/VP8");case"VP9":return f("video/VP9");case"AV1":return f("video/AV1");case"H264":return f("video/H264");default:return x("invalid video codec")}}getSdpFmtpLine(){switch(this.codec){case"VP8":return f("");case"VP9":return f("profile-id=2");case"AV1":return f("level-idx=5;profile=0;tier=0");case"H264":return f("level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42e01f");default:return x("invalid video codec")}}};function Je(t,e){for(let r of t)if(e(r))return r}function Ge(){return typeof AudioContext<"u"&&typeof Worker<"u"}function He(){return typeof SharedArrayBuffer<"u"}function ae(){return/(apple)?webkit\/537\.36/i.test(globalThis.navigator.userAgent)}function $e(){return/electron/i.test(globalThis.navigator.userAgent)}function qe(){return/firefox|iceweasel|fxios/i.test(globalThis.navigator.userAgent)}function We(){return ae()?!1:/safari|applewebkit/i.test(globalThis.navigator.userAgent)}function Ze(t){return JSON.parse(JSON.stringify(t))}var K=class t{constructor(e){this._Generators=e;this._Futures=e.map(t.addIndex)}_Futures;async next(){let[e,r]=await Promise.race(this._Futures);return this._Futures[r]=t.addIndex(this._Generators[r],r),e}static async addIndex(e,r){return[await e(),r]}};function Ke(t,e){return t<=0?Promise.resolve(e):new Promise(r=>setTimeout(()=>r(e),t))}function Ye(t,e){return e.aborted?Promise.resolve("aborted"):new Promise(r=>{let s=()=>r("aborted");e.addEventListener("abort",s,{once:!0}),setTimeout(()=>{e.removeEventListener("abort",s),r(void 0)},t)})}function Qe(){return new Promise(t=>setTimeout(t,0))}var Y=class{_Tasks=[];_Running=!1;_Values;constructor(...e){this._Values=e}enqueue(e){return new Promise((r,s)=>{let u=async()=>{try{let g=await e(...this._Values);r(g)}catch(g){s(g)}};this._Tasks.push(u),this._Running||this.execute()})}async execute(){for(this._Running=!0;;){let e=this._Tasks.shift();if(e===void 0)break;await e()}this._Running=!1}};function Xe(t){let e=t.trim();t.indexOf("://")===-1&&(e=`https://${e}`);try{return f(new URL(e))}catch(r){return x(String(r))}}function et(t,e){let r=t.pathname;r.endsWith("/")===!1&&(r+="/");try{return f(new URL(r+e,t))}catch(s){return x(String(s))}}var tt=/^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;function rt(){return crypto.randomUUID()}function nt(t){return tt.test(t)}function ot(t,e){return e in t}function it(t){return typeof t=="function"}function at(t){return typeof t=="object"&&t===null}function J(t){return typeof t=="number"}function st(t){return typeof t=="object"}function ct(t){return typeof t=="string"}function pt(t){return typeof t>"u"}function ut(t){return t.type==="Failure"}function dt(t){return t.type==="Success"}var C=(g=>(g[g.NONE=0]="NONE",g[g.ERROR=1]="ERROR",g[g.WARN=2]="WARN",g[g.INFO=3]="INFO",g[g.DEBUG=4]="DEBUG",g))(C||{}),G=Object.values(C).filter(t=>!isNaN(Number(t))),se=Object.keys(C).filter(t=>isNaN(Number(t))),ce={0:"\u26AB",1:"\u{1F534}",2:"\u{1F7E1}",3:"\u{1F535}",4:"\u{1F7E3}"},pe={0:console.log,1:console.error,2:console.warn,3:console.info,4:console.debug};function P(t){let e=C[t];return e===void 0?x(`invalid log level name '${t}'; valid names are: ${se.join(", ")}`):f(e)}function L(t){let e=C[t];return e===void 0?x(`invalid log level ${t}; valid levels are: ${G[0]}-${G[G.length-1]}`):f(e)}var S="default",ue=new Map;function k(t=S){let e=ue.get(t);return e||(e=new H("WARN",t)),e}function lt(t,...e){return t instanceof Function?k(S).error(t,...e):k(S).error(t,...e)}function mt(t,...e){return t instanceof Function?k(S).warn(t,...e):k(S).warn(t,...e)}function ft(t,...e){return t instanceof Function?k(S).info(t,...e):k(S).info(t,...e)}function gt(t,...e){return t instanceof Function?k(S).debug(t,...e):k(S).debug(t,...e)}var H=class{name;_Level;_Handlers;constructor(e,r,s){this.name=r??S,J(e)?this._Level=b(P(b(L(e)))):this._Level=b(P(e)),this._Handlers=s?.handlers||[new $(e)],ue.set(this.name,this)}get level(){return this._Level}set level(e){this.levelName=b(L(e))}get levelName(){return b(L(this._Level))}set levelName(e){this._Level=b(P(e)),this._Handlers.forEach(r=>r.level=this._Level)}get handlers(){return this._Handlers}addHandler(e){this._Handlers.push(e)}removeHandler(e){let r=this._Handlers.indexOf(e);r!==-1&&this._Handlers.splice(r,1)}log(e,r,...s){if(this.level<e)return r instanceof Function?void 0:r;let u,g;return r instanceof Function?(u=r(),g=this.asString(u)):g=this.asString(r),this._Handlers.forEach(m=>{m.handle({date:new Date,level:e,levelName:b(L(e)),logger:this.name,message:g,args:s})}),r instanceof Function?u:r}error(e,...r){return this.log(1,e,...r)}warn(e,...r){return this.log(2,e,...r)}info(e,...r){return this.log(3,e,...r)}debug(e,...r){return this.log(4,e,...r)}asString(e,r=!1){return typeof e=="string"?r?`"${e}"`:e:e===null||typeof e=="number"||typeof e=="bigint"||typeof e=="boolean"||typeof e>"u"||typeof e=="symbol"?String(e):e instanceof Error?e.stack:typeof e=="object"?`{${Object.entries(e).map(([s,u])=>`"${s}":${this.asString(u,!0)}`).join(",")}}`:"undefined"}},de=({message:t})=>t,yt=t=>{let e=`[${t.date.toISOString()}]`,r=`[${t.levelName}]`,s=t.logger!==S?`[${t.logger}] `:"",u=ce[t.level];return`${e} ${u} ${r.padEnd(7," ")} ${s}${t.message}`},$=class{_Level;_FormatterFn;constructor(e,r=de){J(e)?this._Level=b(P(b(L(e)))):this._Level=b(P(e)),this._FormatterFn=r}get level(){return this._Level}set level(e){this.levelName=b(L(e))}get levelName(){return b(L(this._Level))}set levelName(e){this._Level=b(P(e))}handle(e){this._Level<e.level||this.log(this._FormatterFn(e),e)}log(e,r){pe[r.level](e,...r.args)}};var br=-758.596,le;(e=>{let t;(m=>(m[m.InvalidPassword=-1]="InvalidPassword",m[m.Unknown=0]="Unknown",m[m.Unencrypted=1]="Unencrypted",m[m.Encrypted=2]="Encrypted"))(t=e.PeerCipherStatus||={})})(le||={});var xt={bytesSent:0,bytesReceived:0,packetsSent:0,packetsReceived:0,rtt:0,packetLoss:0},bt={packetsBuffered:0,packetsSeen:0,packetsProcessed:0,packetsTooEarly:0,packetsTooLate:0,packetsDropped:0,packetsInvalid:0,packetsRepeated:0,packetsLost:0},vt={voiceActivity:{attackThreshold:.9,releaseThreshold:.8},volumeGate:{attackThreshold:-30,releaseThreshold:-40}},Tt={echoCanceller:!0,highPassFilter:!1,noiseSuppression:"Moderate",transientSuppressor:!1,gainController:!0};0&&(module.exports={APM_DEFAULTS,Backend,ByteArraySchema,CONNECTION_STATS_INITIAL,ChannelSet,ChannelSetSchema,DEFAULT_FORMATTER,JITTER_STATS_INITIAL,JsonSchema,LogFunctions,LogHandler,LogLevelNames,LogLevels,LogSymbols,LogVerbosity,Logger,MainCommandsRpc,MainNotificationSchema,MainNotificationsRpc,MediaAudioPropertiesSchema,MediaIdSchema,MediaPropertiesSchema,MediaSchema,MediaVideoPropertiesSchema,MessagePackRpcSchema,MessageReceivedSchema,MinDBFS,PRETTY_FORMATTER,PeerIdSchema,PeerPositionSchema,PeerSchema,PeerUpdateSchema,RoomCommandsRpc,RoomNotificationSchema,RoomNotificationsRpc,RoomV1,RoomV2,Selector,Strand,TokenAudienceSchema,TokenClaimsSchema,TokenSubjectSchema,VAD_DEFAULTS,VideoCodec,WebRtcUpdateSchema,abortableSleep,assert,debug,error,extendUrl,fail,failure,find,fromBase64,fromBase64Url,fromBytes,generateUUID,getLevelByName,getLevelName,getLogger,info,isAudioCapable,isBlinkBrowser,isElectronBrowser,isFailure,isFirefoxBrowser,isFunction,isNull,isNumber,isObject,isProperty,isSafariBrowser,isSharedArrayBufferCapable,isString,isSuccess,isUndefined,nextTick,normalizeUrl,oneOrMany,sleep,success,toBytes,toRaw,unwrap,unwrapOr,validateUUID,warn});
|
|
1
|
+
var xe=Object.create;var w=Object.defineProperty;var he=Object.getOwnPropertyDescriptor;var Se=Object.getOwnPropertyNames;var ze=Object.getPrototypeOf,ve=Object.prototype.hasOwnProperty;var ke=(e,t)=>{for(var o in t)w(e,o,{get:t[o],enumerable:!0})},$=(e,t,o,c)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Se(t))!ve.call(e,s)&&s!==o&&w(e,s,{get:()=>t[s],enumerable:!(c=he(t,s))||c.enumerable});return e};var v=(e,t,o)=>(o=e!=null?xe(ze(e)):{},$(t||!e||!e.__esModule?w(o,"default",{value:e,enumerable:!0}):o,e)),Pe=e=>$(w({},"__esModule",{value:!0}),e);var ht={};ke(ht,{APM_DEFAULTS:()=>xt,Backend:()=>pe,ByteArraySchema:()=>y,CONNECTION_STATS_INITIAL:()=>yt,ChannelSet:()=>I,ChannelSetSchema:()=>V,ConsoleSink:()=>E,Formatter:()=>ae,GLOBAL_LOGGER:()=>se,JITTER_STATS_INITIAL:()=>gt,JsonSchema:()=>P,LogFilter:()=>B,LogLevel:()=>H,LogSymbols:()=>ie,Logger:()=>O,MainCommandsRpc:()=>Ae,MainNotificationSchema:()=>Le,MainNotificationsRpc:()=>je,MediaAudioPropertiesSchema:()=>K,MediaIdSchema:()=>h,MediaPropertiesSchema:()=>L,MediaSchema:()=>j,MediaVideoPropertiesSchema:()=>Q,MessagePackRpcSchema:()=>Ce,MessageReceivedSchema:()=>D,MinDBFS:()=>fr,PeerIdSchema:()=>g,PeerPositionSchema:()=>C,PeerSchema:()=>M,PeerUpdateSchema:()=>_,RoomCommandsRpc:()=>we,RoomNotificationSchema:()=>Me,RoomNotificationsRpc:()=>_e,RoomV1:()=>z,RoomV2:()=>Y,Selector:()=>q,Strand:()=>W,TokenAudienceSchema:()=>G,TokenClaimsSchema:()=>Re,TokenSubjectSchema:()=>Z,VAD_DEFAULTS:()=>bt,VideoCodec:()=>N,WebRtcUpdateSchema:()=>k,abortableSleep:()=>Ge,assert:()=>R,debug:()=>ft,error:()=>ut,extendUrl:()=>Qe,fail:()=>J,failure:()=>x,find:()=>Oe,fromBase64:()=>Ie,fromBase64Url:()=>De,fromBytes:()=>Be,generateUUID:()=>Ye,info:()=>mt,isAudioCapable:()=>Ve,isBlinkBrowser:()=>te,isElectronBrowser:()=>Ne,isFailure:()=>pt,isFirefoxBrowser:()=>qe,isFunction:()=>rt,isNull:()=>ot,isNumber:()=>nt,isObject:()=>it,isProperty:()=>tt,isSafariBrowser:()=>We,isSharedArrayBufferCapable:()=>Je,isString:()=>at,isSuccess:()=>ct,isUndefined:()=>st,log:()=>A,nextTick:()=>Ze,normalizeUrl:()=>Ke,oneOrMany:()=>T,sleep:()=>$e,success:()=>f,toBytes:()=>Fe,toRaw:()=>He,tryParseLogFilter:()=>dt,unwrap:()=>Ue,unwrapOr:()=>F,validateUUID:()=>et,warn:()=>lt});module.exports=Pe(ht);var l=require("zod"),y=l.z.custom(e=>e instanceof Uint8Array),Te=l.z.union([l.z.string(),l.z.number(),l.z.boolean(),l.z.null()]),P=l.z.lazy(()=>l.z.union([Te,l.z.array(P),l.z.record(P)])),Ce=l.z.union([l.z.tuple([l.z.literal(0),l.z.number(),l.z.string(),l.z.unknown()]),l.z.tuple([l.z.literal(1),l.z.number(),l.z.nullable(l.z.string()),l.z.unknown()]),l.z.tuple([l.z.literal(2),l.z.string(),l.z.unknown()])]);var d=require("zod"),G=d.z.enum(["sfu","gateway"]),Z=d.z.enum(["connect","roomclose","roomupdate","roombanclient","roomsendmessage"]),Re=d.z.object({uid:d.z.string(),cid:d.z.optional(d.z.string()),rid:T(d.z.string()).refine(e=>e.length>=1,{message:"missing rid"}),nsp:d.z.optional(d.z.string()),adr:d.z.optional(d.z.string()),aud:d.z.optional(T(G)),sub:d.z.optional(T(Z)),exp:d.z.optional(d.z.number()),nbf:d.z.optional(d.z.number()),ups:d.z.optional(d.z.string()),tgs:d.z.optional(T(d.z.string())),tsp:d.z.optional(d.z.number()),internal:d.z.optional(d.z.object({server:d.z.optional(d.z.string())}))});function T(e){return d.z.union([e.transform(t=>[t]),d.z.array(e)])}var r=v(require("zod"));var u=v(require("zod")),h=u.number(),K=u.object({kind:u.optional(u.literal("audio")),uid:u.optional(u.string()),customType:u.optional(u.string())}),Q=u.object({kind:u.optional(u.literal("video")),codec:u.optional(u.string()),uid:u.optional(u.string()),customType:u.optional(u.string()),id:u.optional(u.string())}),L=u.union([K,Q]),j=u.object({id:h,properties:L,paused:u.boolean()});var m=v(require("zod"));var g=m.number(),C=m.union([m.tuple([m.number(),m.number(),m.number()]),m.tuple([m.number(),m.number()])]),M=m.object({id:g,user_id:m.string(),user_data:y,medias:m.array(j)}),_=m.discriminatedUnion("kind",[m.object({kind:m.literal("UserDataChanged"),peer_id:g,user_data:y}),m.object({kind:m.literal("MediaStarted"),peer_id:g,media:j}),m.object({kind:m.literal("MediaStopped"),peer_id:g,media_id:h})]);var X=v(require("zod")),I=class e{constructor(t=BigInt(0)){this.value=t}from(...t){let o=t.reduce((c,s)=>c|U(s),BigInt(0));return new e(o)}contains(t){return(this.value&U(t))!==BigInt(0)}insert(t){this.value|=U(t)}remove(t){this.value&=~U(t)}[Symbol.iterator](){let t=-1,o=new e(this.value);return{next(){for(;t<63;)if(t+=1,o.contains(t))return{value:t,done:!1};return{value:void 0,done:!0}}}}},V=X.bigint().transform(e=>new I(e));function U(e){return BigInt(1)<<BigInt(e)}var z;(i=>(i.RoomIdSchema=r.string(),i.RoomSchema=r.object({id:i.RoomIdSchema,customer:r.string(),user_data:y,peers:r.array(M)}),i.RoomUpdateSchema=r.discriminatedUnion("kind",[r.object({kind:r.literal("Joined"),room:i.RoomSchema,media_ids:r.array(h),own_peer_id:g}),r.object({kind:r.literal("Left"),reason:r.enum(["RoomClosing","ServerClosing","PeerKicked"])}),r.object({kind:r.literal("UserDataChanged"),user_data:r.optional(y)}),r.object({kind:r.literal("PeerJoined"),peer:M}),r.object({kind:r.literal("PeerLeft"),peer_id:g})]),i.RoomUpdatesSchema=r.object({updates:r.array(i.RoomUpdateSchema)}),i.RoomStatusSchema=r.enum(["Joining","Joined","Closed"]),i.RoomStatusChangedSchema=r.object({status:i.RoomStatusSchema,message:r.optional(r.string())})))(z||={});var Y;(a=>(a.ParametersSchema=r.record(P),a.PeerProperties=r.object({user_data:y.optional(),tags:r.array(r.string()).optional(),audio_parameters:a.ParametersSchema.optional(),video_parameters:a.ParametersSchema.optional()}),a.PingSchema=r.object({Ping:r.object({id:r.number()})}),a.ChangeSelfSchema=r.object({ChangeSelf:a.PeerProperties.omit({tags:!0})}),a.SetAudioMaskSchema=r.object({SetAudioMask:r.object({peer_id:r.number(),mask:V})}),a.SendMessageSchema=r.object({SendMessage:r.object({peer_ids:r.number().array().default([]),message:y})}),a.CallSchema=a.PingSchema.or(a.ChangeSelfSchema).or(a.SetAudioMaskSchema).or(a.SendMessageSchema),a.PongSchema=r.object({Pong:r.object({id:r.number()})}),a.JoinedSchema=r.object({Joined:r.object({own_peer_id:r.number(),room_id:r.string(),customer:r.string()})}),a.LeftSchema=r.object({Left:r.object({reason:r.enum(["room_closing","server_closing","peer_kicked"])})}),a.PeerJoinedSchema=r.object({PeerJoined:a.PeerProperties.extend({peer_id:r.number(),user_id:r.string()})}),a.PeerLeftSchema=r.object({PeerLeft:r.object({peer_id:r.number()})}),a.PeerChangedSchema=r.object({PeerChanged:a.PeerProperties.extend({peer_id:r.number()})}),a.NewReconnectTokenSchema=r.object({NewReconnectToken:r.object({token:r.string()})}),a.MessageReceivedSchema=r.object({MessageReceived:r.object({sender_peer_id:r.number(),message:y})}),a.ErrorSchema=r.object({Error:r.object({message:y})}),a.EventSchema=a.PongSchema.or(a.JoinedSchema).or(a.LeftSchema).or(a.PeerJoinedSchema).or(a.PeerLeftSchema).or(a.PeerChangedSchema).or(a.NewReconnectTokenSchema).or(a.MessageReceivedSchema).or(a.ErrorSchema)))(Y||={});var ee=require("zod");var D=ee.z.object({sender_peer_id:g,message:y});var p=v(require("zod"));var k=p.discriminatedUnion("kind",[p.object({kind:p.literal("Sdp"),type:p.enum(["Answer","Offer"]),sdp:p.string(),media_map:p.array(p.tuple([h,p.string()]))}),p.object({kind:p.literal("Trickle"),candidate:p.string(),spd_mid:p.optional(p.string()),spd_mline_index:p.optional(p.number()),username_fragment:p.optional(p.union([p.string(),p.null()]))}),p.object({kind:p.literal("TrickleFinished")})]);var n=require("zod");var Ae={Hello:{request:n.z.object({stream:n.z.literal("main")}),response:n.z.null()},JoinRoom:{request:n.z.object({token:n.z.string(),room_id:z.RoomIdSchema,user_data:y,position:C}),response:n.z.object({peer_id:g,stream_id:n.z.optional(n.z.number()),token:n.z.optional(n.z.string())})},WebRtcUpdate:{request:k,response:n.z.null()},RequestReconnectToken:{request:n.z.object({peer_id:n.z.optional(g)}),response:n.z.string()},Ping:{request:n.z.object({}),response:n.z.null()}},we={Hello:{request:n.z.object({stream:n.z.literal("room"),token:n.z.string(),room_id:n.z.string(),user_data:y,position:C}),response:n.z.null()},UpdatePeer:{request:n.z.object({user_data:y}),response:n.z.null()},StartMedia:{request:n.z.object({media_id:h,properties:L}),response:n.z.null()},StopMedia:{request:n.z.object({media_id:h}),response:n.z.null()},PauseMedia:{request:n.z.object({media_id:h}),response:n.z.null()},ResumeMedia:{request:n.z.object({media_id:h}),response:n.z.null()},SetPeerPosition:{request:n.z.object({position:C}),response:n.z.null()},SendMessage:{request:n.z.object({target_peer_ids:n.z.optional(n.z.array(g)),message:y}),response:n.z.null()}};var b=v(require("zod"));var Le=b.object({name:b.literal("WebRtcUpdate"),properties:k}),je={WebRtcUpdate:k},Me=b.union([b.object({name:b.literal("RoomStatusChanged"),properties:z.RoomStatusChangedSchema}),b.object({name:b.literal("RoomUpdated"),properties:z.RoomUpdatesSchema}),b.object({name:b.literal("PeerUpdated"),properties:_}),b.object({name:b.literal("MessageReceived"),properties:D})]),_e={RoomStatusChanged:z.RoomStatusChangedSchema,RoomUpdated:z.RoomUpdatesSchema,PeerUpdated:_,MessageReceived:D};function R(e,t){e||J(t)}function J(e){throw new Error(e)}function f(e){return{type:"Success",value:e}}function x(e){return{type:"Failure",reason:e}}function Ue(e){return e.type==="Failure"&&J(e.reason),e.value}function F(e,t){return e.type==="Success"?e.value:t}function Ie(e){try{let t=atob(e),o=Uint8Array.from(t,s=>s.codePointAt(0)),c=new TextDecoder("utf8");return f(c.decode(o))}catch(t){return x(String(t))}}function De(e){try{let t=atob(e.replace(/-/g,"+").replace(/_/g,"/")),o=Uint8Array.from(t,s=>s.codePointAt(0)),c=new TextDecoder("utf8");return f(c.decode(o))}catch(t){return x(String(t))}}function Fe(e){try{R(e!==void 0,"undefined cannot be converted to byte array"),R(e!==null,"null cannot be converted to byte array");let t=JSON.stringify(e),o=new TextEncoder;return f(o.encode(t))}catch(t){return x(String(t))}}function Be(e){try{R(e.length>0,"empty byte array cannot be converted to value");let t=new TextDecoder().decode(e),o=JSON.parse(t);return f(o)}catch(t){return x(String(t))}}var Ee=["VP8","VP9","AV1","H264"],N=class{constructor(t){this.codec=t}channels=0;clockRate=9e4;isValid(){return Ee.includes(this.codec)}isSupported(){if(typeof RTCRtpReceiver>"u"||typeof RTCRtpReceiver.getCapabilities>"u")return null;let t=F(this.getMimeType(),"").toLowerCase(),o=new Set(F(this.getSdpFmtpLine(),"").split(";").map(c=>c.trim().toLowerCase()));return RTCRtpReceiver.getCapabilities("video")?.codecs?.find(c=>{let s=c.mimeType.toLowerCase(),S=new Set((c.sdpFmtpLine??"").split(";").map(i=>i.trim().toLowerCase()));if(t!==s||o.size!==S.size)return!1;for(let i of o)if(!S.has(i))return!1;return!0})??null}getPayloadType(){switch(this.codec){case"VP8":return f(96);case"VP9":return f(98);case"AV1":return f(41);case"H264":return f(102);default:return x("invalid video codec")}}getMimeType(){switch(this.codec){case"VP8":return f("video/VP8");case"VP9":return f("video/VP9");case"AV1":return f("video/AV1");case"H264":return f("video/H264");default:return x("invalid video codec")}}getSdpFmtpLine(){switch(this.codec){case"VP8":return f("");case"VP9":return f("profile-id=2");case"AV1":return f("level-idx=5;profile=0;tier=0");case"H264":return f("level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42e01f");default:return x("invalid video codec")}}};function Oe(e,t){for(let o of e)if(t(o))return o}function Ve(){return typeof AudioContext<"u"&&typeof Worker<"u"}function Je(){return typeof SharedArrayBuffer<"u"}function te(){return/(apple)?webkit\/537\.36/i.test(globalThis.navigator.userAgent)}function Ne(){return/electron/i.test(globalThis.navigator.userAgent)}function qe(){return/firefox|iceweasel|fxios/i.test(globalThis.navigator.userAgent)}function We(){return te()?!1:/safari|applewebkit/i.test(globalThis.navigator.userAgent)}function He(e){return JSON.parse(JSON.stringify(e))}var q=class e{constructor(t){this._Generators=t;this._Futures=t.map(e.addIndex)}_Futures;async next(){let[t,o]=await Promise.race(this._Futures);return this._Futures[o]=e.addIndex(this._Generators[o],o),t}static async addIndex(t,o){return[await t(),o]}};function $e(e,t){return e<=0?Promise.resolve(t):new Promise(o=>setTimeout(()=>o(t),e))}function Ge(e,t){return t.aborted?Promise.resolve("aborted"):new Promise(o=>{let c=()=>o("aborted");t.addEventListener("abort",c,{once:!0}),setTimeout(()=>{t.removeEventListener("abort",c),o(void 0)},e)})}function Ze(){return new Promise(e=>setTimeout(e,0))}var W=class{_Tasks=[];_Running=!1;_Values;constructor(...t){this._Values=t}enqueue(t){return new Promise((o,c)=>{let s=async()=>{try{let S=await t(...this._Values);o(S)}catch(S){c(S)}};this._Tasks.push(s),this._Running||this.execute()})}async execute(){for(this._Running=!0;;){let t=this._Tasks.shift();if(t===void 0)break;await t()}this._Running=!1}};function Ke(e){let t=e.trim();e.indexOf("://")===-1&&(t=`https://${t}`);try{return f(new URL(t))}catch(o){return x(String(o))}}function Qe(e,t){let o=e.pathname;o.endsWith("/")===!1&&(o+="/");try{return f(new URL(o+t,e))}catch(c){return x(String(c))}}var Xe=/^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;function Ye(){return crypto.randomUUID()}function et(e){return Xe.test(e)}function tt(e,t){return t in e}function rt(e){return typeof e=="function"}function ot(e){return typeof e=="object"&&e===null}function nt(e){return typeof e=="number"}function it(e){return typeof e=="object"}function at(e){return typeof e=="string"}function st(e){return typeof e>"u"}function pt(e){return e.type==="Failure"}function ct(e){return e.type==="Success"}var B=(i=>(i[i.Nothing=0]="Nothing",i[i.Error=1]="Error",i[i.Warn=2]="Warn",i[i.Info=3]="Info",i[i.Debug=4]="Debug",i[i.Everything=5]="Everything",i))(B||{}),H=(s=>(s[s.Error=1]="Error",s[s.Warn=2]="Warn",s[s.Info=3]="Info",s[s.Debug=4]="Debug",s))(H||{}),ie={1:"\u{1F534}",2:"\u{1F7E1}",3:"\u{1F535}",4:"\u{1F7E3}"};function dt(e){for(let t of Object.keys(B))if(isNaN(Number(t))!==!1&&t.localeCompare(e,void 0,{sensitivity:"accent"})===0)return B[t]}function re({message:e}){return String(e)}function oe(e){let t=`[${e.date.toISOString()}]`,o=`[${H[e.level]}]`,c=e.logger.name!==void 0?`[${e.logger}] `:"",s=ie[e.level];return`${t} ${s} ${o.padEnd(7," ")} ${c}${e.message}`}var ae={sparse:re,pretty:oe,default:Deno.stdout.isTerminal()?oe:re},E=class{#e;#t;filter;constructor(t=ae.default,o=5,c=console){this.filter=o,this.#e=t,this.#t=c}handle(t){let o=this.#e(t);switch(t.level){case 1:this.#t.error(o,...t.extra);break;case 2:this.#t.warn(o,...t.extra);break;case 3:this.#t.info(o,...t.extra);break;case 4:this.#t.debug(o,...t.extra);break}}},O=class{#e;sinks;filter;get name(){return this.#e}constructor(t,o=void 0,c=[new E]){this.#e=o,this.sinks=c,this.filter=t}log(t,o,...c){if(this.filter<t)return;let s=ne;for(let S of this.sinks)S.filter<t||(s===ne&&(s={date:new Date,level:t,logger:this,message:typeof o=="function"?o():o,extra:c}),S.handle(s))}},se=new O(3);function A(e,t,...o){se.log(e,t,o)}var ut=A.bind(void 0,1),lt=A.bind(void 0,2),mt=A.bind(void 0,3),ft=A.bind(void 0,4),ne=Symbol();var fr=-758.596,pe;(t=>{let e;(i=>(i[i.InvalidPassword=-1]="InvalidPassword",i[i.Unknown=0]="Unknown",i[i.Unencrypted=1]="Unencrypted",i[i.Encrypted=2]="Encrypted"))(e=t.PeerCipherStatus||={})})(pe||={});var yt={bytesSent:0,bytesReceived:0,packetsSent:0,packetsReceived:0,rtt:0,packetLoss:0},gt={packetsBuffered:0,packetsSeen:0,packetsProcessed:0,packetsTooEarly:0,packetsTooLate:0,packetsDropped:0,packetsInvalid:0,packetsRepeated:0,packetsLost:0},bt={voiceActivity:{attackThreshold:.9,releaseThreshold:.8},volumeGate:{attackThreshold:-30,releaseThreshold:-40}},xt={echoCanceller:!0,highPassFilter:!1,noiseSuppression:"Moderate",transientSuppressor:!1,gainController:!0};0&&(module.exports={APM_DEFAULTS,Backend,ByteArraySchema,CONNECTION_STATS_INITIAL,ChannelSet,ChannelSetSchema,ConsoleSink,Formatter,GLOBAL_LOGGER,JITTER_STATS_INITIAL,JsonSchema,LogFilter,LogLevel,LogSymbols,Logger,MainCommandsRpc,MainNotificationSchema,MainNotificationsRpc,MediaAudioPropertiesSchema,MediaIdSchema,MediaPropertiesSchema,MediaSchema,MediaVideoPropertiesSchema,MessagePackRpcSchema,MessageReceivedSchema,MinDBFS,PeerIdSchema,PeerPositionSchema,PeerSchema,PeerUpdateSchema,RoomCommandsRpc,RoomNotificationSchema,RoomNotificationsRpc,RoomV1,RoomV2,Selector,Strand,TokenAudienceSchema,TokenClaimsSchema,TokenSubjectSchema,VAD_DEFAULTS,VideoCodec,WebRtcUpdateSchema,abortableSleep,assert,debug,error,extendUrl,fail,failure,find,fromBase64,fromBase64Url,fromBytes,generateUUID,info,isAudioCapable,isBlinkBrowser,isElectronBrowser,isFailure,isFirefoxBrowser,isFunction,isNull,isNumber,isObject,isProperty,isSafariBrowser,isSharedArrayBufferCapable,isString,isSuccess,isUndefined,log,nextTick,normalizeUrl,oneOrMany,sleep,success,toBytes,toRaw,tryParseLogFilter,unwrap,unwrapOr,validateUUID,warn});
|
package/esm/mod.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{z as l}from"zod";var y=l.custom(t=>t instanceof Uint8Array),se=l.union([l.string(),l.number(),l.boolean(),l.null()]),C=l.lazy(()=>l.union([se,l.array(C),l.record(C)])),ke=l.union([l.tuple([l.literal(0),l.number(),l.string(),l.unknown()]),l.tuple([l.literal(1),l.number(),l.nullable(l.string()),l.unknown()]),l.tuple([l.literal(2),l.string(),l.unknown()])]);import{z as s}from"zod";var ce=s.enum(["sfu","gateway"]),pe=s.enum(["connect","roomclose","roomupdate","roombanclient","roomsendmessage"]),Re=s.object({uid:s.string(),cid:s.optional(s.string()),rid:_(s.string()).refine(t=>t.length>=1,{message:"missing rid"}),nsp:s.optional(s.string()),adr:s.optional(s.string()),aud:s.optional(_(ce)),sub:s.optional(_(pe)),exp:s.optional(s.number()),nbf:s.optional(s.number()),ups:s.optional(s.string()),tgs:s.optional(_(s.string())),tsp:s.optional(s.number()),internal:s.optional(s.object({server:s.optional(s.string())}))});function _(t){return s.union([t.transform(e=>[e]),s.array(t)])}import*as r from"zod";import*as c from"zod";var h=c.number(),ue=c.object({kind:c.optional(c.literal("audio")),uid:c.optional(c.string()),customType:c.optional(c.string())}),de=c.object({kind:c.optional(c.literal("video")),codec:c.optional(c.string()),uid:c.optional(c.string()),customType:c.optional(c.string()),id:c.optional(c.string())}),M=c.union([ue,de]),N=c.object({id:h,properties:M,paused:c.boolean()});import*as u from"zod";var T=u.number(),A=u.union([u.tuple([u.number(),u.number(),u.number()]),u.tuple([u.number(),u.number()])]),U=u.object({id:T,user_id:u.string(),user_data:y,medias:u.array(N)}),I=u.discriminatedUnion("kind",[u.object({kind:u.literal("UserDataChanged"),peer_id:T,user_data:y}),u.object({kind:u.literal("MediaStarted"),peer_id:T,media:N}),u.object({kind:u.literal("MediaStopped"),peer_id:T,media_id:h})]);import*as H from"zod";var O=class t{constructor(e=BigInt(0)){this.value=e}from(...e){let n=e.reduce((p,g)=>p|j(g),BigInt(0));return new t(n)}contains(e){return(this.value&j(e))!==BigInt(0)}insert(e){this.value|=j(e)}remove(e){this.value&=~j(e)}[Symbol.iterator](){let e=-1,n=new t(this.value);return{next(){for(;e<63;)if(e+=1,n.contains(e))return{value:e,done:!1};return{value:void 0,done:!0}}}}},$=H.bigint().transform(t=>new O(t));function j(t){return BigInt(1)<<BigInt(t)}var z;(d=>(d.RoomIdSchema=r.string(),d.RoomSchema=r.object({id:d.RoomIdSchema,customer:r.string(),user_data:y,peers:r.array(U)}),d.RoomUpdateSchema=r.discriminatedUnion("kind",[r.object({kind:r.literal("Joined"),room:d.RoomSchema,media_ids:r.array(h),own_peer_id:T}),r.object({kind:r.literal("Left"),reason:r.enum(["RoomClosing","ServerClosing","PeerKicked"])}),r.object({kind:r.literal("UserDataChanged"),user_data:r.optional(y)}),r.object({kind:r.literal("PeerJoined"),peer:U}),r.object({kind:r.literal("PeerLeft"),peer_id:T})]),d.RoomUpdatesSchema=r.object({updates:r.array(d.RoomUpdateSchema)}),d.RoomStatusSchema=r.enum(["Joining","Joined","Closed"]),d.RoomStatusChangedSchema=r.object({status:d.RoomStatusSchema,message:r.optional(r.string())})))(z||={});var le;(i=>(i.ParametersSchema=r.record(C),i.PeerProperties=r.object({user_data:y.optional(),tags:r.array(r.string()).optional(),audio_parameters:i.ParametersSchema.optional(),video_parameters:i.ParametersSchema.optional()}),i.PingSchema=r.object({Ping:r.object({id:r.number()})}),i.ChangeSelfSchema=r.object({ChangeSelf:i.PeerProperties.omit({tags:!0})}),i.SetAudioMaskSchema=r.object({SetAudioMask:r.object({peer_id:r.number(),mask:$})}),i.SendMessageSchema=r.object({SendMessage:r.object({peer_ids:r.number().array().default([]),message:y})}),i.CallSchema=i.PingSchema.or(i.ChangeSelfSchema).or(i.SetAudioMaskSchema).or(i.SendMessageSchema),i.PongSchema=r.object({Pong:r.object({id:r.number()})}),i.JoinedSchema=r.object({Joined:r.object({own_peer_id:r.number(),room_id:r.string(),customer:r.string()})}),i.LeftSchema=r.object({Left:r.object({reason:r.enum(["room_closing","server_closing","peer_kicked"])})}),i.PeerJoinedSchema=r.object({PeerJoined:i.PeerProperties.extend({peer_id:r.number(),user_id:r.string()})}),i.PeerLeftSchema=r.object({PeerLeft:r.object({peer_id:r.number()})}),i.PeerChangedSchema=r.object({PeerChanged:i.PeerProperties.extend({peer_id:r.number()})}),i.NewReconnectTokenSchema=r.object({NewReconnectToken:r.object({token:r.string()})}),i.MessageReceivedSchema=r.object({MessageReceived:r.object({sender_peer_id:r.number(),message:y})}),i.ErrorSchema=r.object({Error:r.object({message:y})}),i.EventSchema=i.PongSchema.or(i.JoinedSchema).or(i.LeftSchema).or(i.PeerJoinedSchema).or(i.PeerLeftSchema).or(i.PeerChangedSchema).or(i.NewReconnectTokenSchema).or(i.MessageReceivedSchema).or(i.ErrorSchema)))(le||={});import{z as me}from"zod";var E=me.object({sender_peer_id:T,message:y});import*as a from"zod";var R=a.discriminatedUnion("kind",[a.object({kind:a.literal("Sdp"),type:a.enum(["Answer","Offer"]),sdp:a.string(),media_map:a.array(a.tuple([h,a.string()]))}),a.object({kind:a.literal("Trickle"),candidate:a.string(),spd_mid:a.optional(a.string()),spd_mline_index:a.optional(a.number()),username_fragment:a.optional(a.union([a.string(),a.null()]))}),a.object({kind:a.literal("TrickleFinished")})]);import{z as o}from"zod";var Ye={Hello:{request:o.object({stream:o.literal("main")}),response:o.null()},JoinRoom:{request:o.object({token:o.string(),room_id:z.RoomIdSchema,user_data:y,position:A}),response:o.object({peer_id:T,stream_id:o.optional(o.number()),token:o.optional(o.string())})},WebRtcUpdate:{request:R,response:o.null()},RequestReconnectToken:{request:o.object({peer_id:o.optional(T)}),response:o.string()},Ping:{request:o.object({}),response:o.null()}},Qe={Hello:{request:o.object({stream:o.literal("room"),token:o.string(),room_id:o.string(),user_data:y,position:A}),response:o.null()},UpdatePeer:{request:o.object({user_data:y}),response:o.null()},StartMedia:{request:o.object({media_id:h,properties:M}),response:o.null()},StopMedia:{request:o.object({media_id:h}),response:o.null()},PauseMedia:{request:o.object({media_id:h}),response:o.null()},ResumeMedia:{request:o.object({media_id:h}),response:o.null()},SetPeerPosition:{request:o.object({position:A}),response:o.null()},SendMessage:{request:o.object({target_peer_ids:o.optional(o.array(T)),message:y}),response:o.null()}};import*as b from"zod";var ot=b.object({name:b.literal("WebRtcUpdate"),properties:R}),it={WebRtcUpdate:R},at=b.union([b.object({name:b.literal("RoomStatusChanged"),properties:z.RoomStatusChangedSchema}),b.object({name:b.literal("RoomUpdated"),properties:z.RoomUpdatesSchema}),b.object({name:b.literal("PeerUpdated"),properties:I}),b.object({name:b.literal("MessageReceived"),properties:E})]),st={RoomStatusChanged:z.RoomStatusChangedSchema,RoomUpdated:z.RoomUpdatesSchema,PeerUpdated:I,MessageReceived:E};function F(t,e){t||q(e)}function q(t){throw new Error(t)}function m(t){return{type:"Success",value:t}}function x(t){return{type:"Failure",reason:t}}function v(t){return t.type==="Failure"&&q(t.reason),t.value}function D(t,e){return t.type==="Success"?t.value:e}function dt(t){try{let e=atob(t),n=Uint8Array.from(e,g=>g.codePointAt(0)),p=new TextDecoder("utf8");return m(p.decode(n))}catch(e){return x(String(e))}}function lt(t){try{let e=atob(t.replace(/-/g,"+").replace(/_/g,"/")),n=Uint8Array.from(e,g=>g.codePointAt(0)),p=new TextDecoder("utf8");return m(p.decode(n))}catch(e){return x(String(e))}}function gt(t){try{F(t!==void 0,"undefined cannot be converted to byte array"),F(t!==null,"null cannot be converted to byte array");let e=JSON.stringify(t),n=new TextEncoder;return m(n.encode(e))}catch(e){return x(String(e))}}function yt(t){try{F(t.length>0,"empty byte array cannot be converted to value");let e=new TextDecoder().decode(t),n=JSON.parse(e);return m(n)}catch(e){return x(String(e))}}var fe=["VP8","VP9","AV1","H264"],W=class{constructor(e){this.codec=e}channels=0;clockRate=9e4;isValid(){return fe.includes(this.codec)}isSupported(){if(typeof RTCRtpReceiver>"u"||typeof RTCRtpReceiver.getCapabilities>"u")return null;let e=D(this.getMimeType(),"").toLowerCase(),n=new Set(D(this.getSdpFmtpLine(),"").split(";").map(p=>p.trim().toLowerCase()));return RTCRtpReceiver.getCapabilities("video")?.codecs?.find(p=>{let g=p.mimeType.toLowerCase(),f=new Set((p.sdpFmtpLine??"").split(";").map(d=>d.trim().toLowerCase()));if(e!==g||n.size!==f.size)return!1;for(let d of n)if(!f.has(d))return!1;return!0})??null}getPayloadType(){switch(this.codec){case"VP8":return m(96);case"VP9":return m(98);case"AV1":return m(41);case"H264":return m(102);default:return x("invalid video codec")}}getMimeType(){switch(this.codec){case"VP8":return m("video/VP8");case"VP9":return m("video/VP9");case"AV1":return m("video/AV1");case"H264":return m("video/H264");default:return x("invalid video codec")}}getSdpFmtpLine(){switch(this.codec){case"VP8":return m("");case"VP9":return m("profile-id=2");case"AV1":return m("level-idx=5;profile=0;tier=0");case"H264":return m("level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42e01f");default:return x("invalid video codec")}}};function Tt(t,e){for(let n of t)if(e(n))return n}function St(){return typeof AudioContext<"u"&&typeof Worker<"u"}function zt(){return typeof SharedArrayBuffer<"u"}function ge(){return/(apple)?webkit\/537\.36/i.test(globalThis.navigator.userAgent)}function kt(){return/electron/i.test(globalThis.navigator.userAgent)}function Lt(){return/firefox|iceweasel|fxios/i.test(globalThis.navigator.userAgent)}function Pt(){return ge()?!1:/safari|applewebkit/i.test(globalThis.navigator.userAgent)}function wt(t){return JSON.parse(JSON.stringify(t))}var Z=class t{constructor(e){this._Generators=e;this._Futures=e.map(t.addIndex)}_Futures;async next(){let[e,n]=await Promise.race(this._Futures);return this._Futures[n]=t.addIndex(this._Generators[n],n),e}static async addIndex(e,n){return[await e(),n]}};function At(t,e){return t<=0?Promise.resolve(e):new Promise(n=>setTimeout(()=>n(e),t))}function jt(t,e){return e.aborted?Promise.resolve("aborted"):new Promise(n=>{let p=()=>n("aborted");e.addEventListener("abort",p,{once:!0}),setTimeout(()=>{e.removeEventListener("abort",p),n(void 0)},t)})}function Ft(){return new Promise(t=>setTimeout(t,0))}var K=class{_Tasks=[];_Running=!1;_Values;constructor(...e){this._Values=e}enqueue(e){return new Promise((n,p)=>{let g=async()=>{try{let f=await e(...this._Values);n(f)}catch(f){p(f)}};this._Tasks.push(g),this._Running||this.execute()})}async execute(){for(this._Running=!0;;){let e=this._Tasks.shift();if(e===void 0)break;await e()}this._Running=!1}};function It(t){let e=t.trim();t.indexOf("://")===-1&&(e=`https://${e}`);try{return m(new URL(e))}catch(n){return x(String(n))}}function Ot(t,e){let n=t.pathname;n.endsWith("/")===!1&&(n+="/");try{return m(new URL(n+e,t))}catch(p){return x(String(p))}}var ye=/^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;function Dt(){return crypto.randomUUID()}function Vt(t){return ye.test(t)}function Jt(t,e){return e in t}function Gt(t){return typeof t=="function"}function Ht(t){return typeof t=="object"&&t===null}function V(t){return typeof t=="number"}function $t(t){return typeof t=="object"}function qt(t){return typeof t=="string"}function Wt(t){return typeof t>"u"}function Zt(t){return t.type==="Failure"}function Kt(t){return t.type==="Success"}var w=(f=>(f[f.NONE=0]="NONE",f[f.ERROR=1]="ERROR",f[f.WARN=2]="WARN",f[f.INFO=3]="INFO",f[f.DEBUG=4]="DEBUG",f))(w||{}),B=Object.values(w).filter(t=>!isNaN(Number(t))),xe=Object.keys(w).filter(t=>isNaN(Number(t))),be={0:"\u26AB",1:"\u{1F534}",2:"\u{1F7E1}",3:"\u{1F535}",4:"\u{1F7E3}"},ve={0:console.log,1:console.error,2:console.warn,3:console.info,4:console.debug};function P(t){let e=w[t];return e===void 0?x(`invalid log level name '${t}'; valid names are: ${xe.join(", ")}`):m(e)}function L(t){let e=w[t];return e===void 0?x(`invalid log level ${t}; valid levels are: ${B[0]}-${B[B.length-1]}`):m(e)}var S="default",Y=new Map;function k(t=S){let e=Y.get(t);return e||(e=new J("WARN",t)),e}function er(t,...e){return t instanceof Function?k(S).error(t,...e):k(S).error(t,...e)}function tr(t,...e){return t instanceof Function?k(S).warn(t,...e):k(S).warn(t,...e)}function rr(t,...e){return t instanceof Function?k(S).info(t,...e):k(S).info(t,...e)}function nr(t,...e){return t instanceof Function?k(S).debug(t,...e):k(S).debug(t,...e)}var J=class{name;_Level;_Handlers;constructor(e,n,p){this.name=n??S,V(e)?this._Level=v(P(v(L(e)))):this._Level=v(P(e)),this._Handlers=p?.handlers||[new G(e)],Y.set(this.name,this)}get level(){return this._Level}set level(e){this.levelName=v(L(e))}get levelName(){return v(L(this._Level))}set levelName(e){this._Level=v(P(e)),this._Handlers.forEach(n=>n.level=this._Level)}get handlers(){return this._Handlers}addHandler(e){this._Handlers.push(e)}removeHandler(e){let n=this._Handlers.indexOf(e);n!==-1&&this._Handlers.splice(n,1)}log(e,n,...p){if(this.level<e)return n instanceof Function?void 0:n;let g,f;return n instanceof Function?(g=n(),f=this.asString(g)):f=this.asString(n),this._Handlers.forEach(d=>{d.handle({date:new Date,level:e,levelName:v(L(e)),logger:this.name,message:f,args:p})}),n instanceof Function?g:n}error(e,...n){return this.log(1,e,...n)}warn(e,...n){return this.log(2,e,...n)}info(e,...n){return this.log(3,e,...n)}debug(e,...n){return this.log(4,e,...n)}asString(e,n=!1){return typeof e=="string"?n?`"${e}"`:e:e===null||typeof e=="number"||typeof e=="bigint"||typeof e=="boolean"||typeof e>"u"||typeof e=="symbol"?String(e):e instanceof Error?e.stack:typeof e=="object"?`{${Object.entries(e).map(([p,g])=>`"${p}":${this.asString(g,!0)}`).join(",")}}`:"undefined"}},Te=({message:t})=>t,or=t=>{let e=`[${t.date.toISOString()}]`,n=`[${t.levelName}]`,p=t.logger!==S?`[${t.logger}] `:"",g=be[t.level];return`${e} ${g} ${n.padEnd(7," ")} ${p}${t.message}`},G=class{_Level;_FormatterFn;constructor(e,n=Te){V(e)?this._Level=v(P(v(L(e)))):this._Level=v(P(e)),this._FormatterFn=n}get level(){return this._Level}set level(e){this.levelName=v(L(e))}get levelName(){return v(L(this._Level))}set levelName(e){this._Level=v(P(e))}handle(e){this._Level<e.level||this.log(this._FormatterFn(e),e)}log(e,n){ve[n.level](e,...n.args)}};var ar=-758.596,he;(e=>{let t;(d=>(d[d.InvalidPassword=-1]="InvalidPassword",d[d.Unknown=0]="Unknown",d[d.Unencrypted=1]="Unencrypted",d[d.Encrypted=2]="Encrypted"))(t=e.PeerCipherStatus||={})})(he||={});var sr={bytesSent:0,bytesReceived:0,packetsSent:0,packetsReceived:0,rtt:0,packetLoss:0},cr={packetsBuffered:0,packetsSeen:0,packetsProcessed:0,packetsTooEarly:0,packetsTooLate:0,packetsDropped:0,packetsInvalid:0,packetsRepeated:0,packetsLost:0},pr={voiceActivity:{attackThreshold:.9,releaseThreshold:.8},volumeGate:{attackThreshold:-30,releaseThreshold:-40}},ur={echoCanceller:!0,highPassFilter:!1,noiseSuppression:"Moderate",transientSuppressor:!1,gainController:!0};export{ur as APM_DEFAULTS,he as Backend,y as ByteArraySchema,sr as CONNECTION_STATS_INITIAL,O as ChannelSet,$ as ChannelSetSchema,Te as DEFAULT_FORMATTER,cr as JITTER_STATS_INITIAL,C as JsonSchema,ve as LogFunctions,G as LogHandler,xe as LogLevelNames,B as LogLevels,be as LogSymbols,w as LogVerbosity,J as Logger,Ye as MainCommandsRpc,ot as MainNotificationSchema,it as MainNotificationsRpc,ue as MediaAudioPropertiesSchema,h as MediaIdSchema,M as MediaPropertiesSchema,N as MediaSchema,de as MediaVideoPropertiesSchema,ke as MessagePackRpcSchema,E as MessageReceivedSchema,ar as MinDBFS,or as PRETTY_FORMATTER,T as PeerIdSchema,A as PeerPositionSchema,U as PeerSchema,I as PeerUpdateSchema,Qe as RoomCommandsRpc,at as RoomNotificationSchema,st as RoomNotificationsRpc,z as RoomV1,le as RoomV2,Z as Selector,K as Strand,ce as TokenAudienceSchema,Re as TokenClaimsSchema,pe as TokenSubjectSchema,pr as VAD_DEFAULTS,W as VideoCodec,R as WebRtcUpdateSchema,jt as abortableSleep,F as assert,nr as debug,er as error,Ot as extendUrl,q as fail,x as failure,Tt as find,dt as fromBase64,lt as fromBase64Url,yt as fromBytes,Dt as generateUUID,P as getLevelByName,L as getLevelName,k as getLogger,rr as info,St as isAudioCapable,ge as isBlinkBrowser,kt as isElectronBrowser,Zt as isFailure,Lt as isFirefoxBrowser,Gt as isFunction,Ht as isNull,V as isNumber,$t as isObject,Jt as isProperty,Pt as isSafariBrowser,zt as isSharedArrayBufferCapable,qt as isString,Kt as isSuccess,Wt as isUndefined,Ft as nextTick,It as normalizeUrl,_ as oneOrMany,At as sleep,m as success,gt as toBytes,wt as toRaw,v as unwrap,D as unwrapOr,Vt as validateUUID,tr as warn};
|
|
1
|
+
import{z as m}from"zod";var y=m.custom(e=>e instanceof Uint8Array),ne=m.union([m.string(),m.number(),m.boolean(),m.null()]),k=m.lazy(()=>m.union([ne,m.array(k),m.record(k)])),Se=m.union([m.tuple([m.literal(0),m.number(),m.string(),m.unknown()]),m.tuple([m.literal(1),m.number(),m.nullable(m.string()),m.unknown()]),m.tuple([m.literal(2),m.string(),m.unknown()])]);import{z as p}from"zod";var ie=p.enum(["sfu","gateway"]),ae=p.enum(["connect","roomclose","roomupdate","roombanclient","roomsendmessage"]),ke=p.object({uid:p.string(),cid:p.optional(p.string()),rid:P(p.string()).refine(e=>e.length>=1,{message:"missing rid"}),nsp:p.optional(p.string()),adr:p.optional(p.string()),aud:p.optional(P(ie)),sub:p.optional(P(ae)),exp:p.optional(p.number()),nbf:p.optional(p.number()),ups:p.optional(p.string()),tgs:p.optional(P(p.string())),tsp:p.optional(p.number()),internal:p.optional(p.object({server:p.optional(p.string())}))});function P(e){return p.union([e.transform(t=>[t]),p.array(e)])}import*as r from"zod";import*as c from"zod";var S=c.number(),se=c.object({kind:c.optional(c.literal("audio")),uid:c.optional(c.string()),customType:c.optional(c.string())}),pe=c.object({kind:c.optional(c.literal("video")),codec:c.optional(c.string()),uid:c.optional(c.string()),customType:c.optional(c.string()),id:c.optional(c.string())}),w=c.union([se,pe]),L=c.object({id:S,properties:w,paused:c.boolean()});import*as l from"zod";var b=l.number(),T=l.union([l.tuple([l.number(),l.number(),l.number()]),l.tuple([l.number(),l.number()])]),j=l.object({id:b,user_id:l.string(),user_data:y,medias:l.array(L)}),M=l.discriminatedUnion("kind",[l.object({kind:l.literal("UserDataChanged"),peer_id:b,user_data:y}),l.object({kind:l.literal("MediaStarted"),peer_id:b,media:L}),l.object({kind:l.literal("MediaStopped"),peer_id:b,media_id:S})]);import*as E from"zod";var _=class e{constructor(t=BigInt(0)){this.value=t}from(...t){let o=t.reduce((d,u)=>d|C(u),BigInt(0));return new e(o)}contains(t){return(this.value&C(t))!==BigInt(0)}insert(t){this.value|=C(t)}remove(t){this.value&=~C(t)}[Symbol.iterator](){let t=-1,o=new e(this.value);return{next(){for(;t<63;)if(t+=1,o.contains(t))return{value:t,done:!1};return{value:void 0,done:!0}}}}},O=E.bigint().transform(e=>new _(e));function C(e){return BigInt(1)<<BigInt(e)}var z;(n=>(n.RoomIdSchema=r.string(),n.RoomSchema=r.object({id:n.RoomIdSchema,customer:r.string(),user_data:y,peers:r.array(j)}),n.RoomUpdateSchema=r.discriminatedUnion("kind",[r.object({kind:r.literal("Joined"),room:n.RoomSchema,media_ids:r.array(S),own_peer_id:b}),r.object({kind:r.literal("Left"),reason:r.enum(["RoomClosing","ServerClosing","PeerKicked"])}),r.object({kind:r.literal("UserDataChanged"),user_data:r.optional(y)}),r.object({kind:r.literal("PeerJoined"),peer:j}),r.object({kind:r.literal("PeerLeft"),peer_id:b})]),n.RoomUpdatesSchema=r.object({updates:r.array(n.RoomUpdateSchema)}),n.RoomStatusSchema=r.enum(["Joining","Joined","Closed"]),n.RoomStatusChangedSchema=r.object({status:n.RoomStatusSchema,message:r.optional(r.string())})))(z||={});var ce;(a=>(a.ParametersSchema=r.record(k),a.PeerProperties=r.object({user_data:y.optional(),tags:r.array(r.string()).optional(),audio_parameters:a.ParametersSchema.optional(),video_parameters:a.ParametersSchema.optional()}),a.PingSchema=r.object({Ping:r.object({id:r.number()})}),a.ChangeSelfSchema=r.object({ChangeSelf:a.PeerProperties.omit({tags:!0})}),a.SetAudioMaskSchema=r.object({SetAudioMask:r.object({peer_id:r.number(),mask:O})}),a.SendMessageSchema=r.object({SendMessage:r.object({peer_ids:r.number().array().default([]),message:y})}),a.CallSchema=a.PingSchema.or(a.ChangeSelfSchema).or(a.SetAudioMaskSchema).or(a.SendMessageSchema),a.PongSchema=r.object({Pong:r.object({id:r.number()})}),a.JoinedSchema=r.object({Joined:r.object({own_peer_id:r.number(),room_id:r.string(),customer:r.string()})}),a.LeftSchema=r.object({Left:r.object({reason:r.enum(["room_closing","server_closing","peer_kicked"])})}),a.PeerJoinedSchema=r.object({PeerJoined:a.PeerProperties.extend({peer_id:r.number(),user_id:r.string()})}),a.PeerLeftSchema=r.object({PeerLeft:r.object({peer_id:r.number()})}),a.PeerChangedSchema=r.object({PeerChanged:a.PeerProperties.extend({peer_id:r.number()})}),a.NewReconnectTokenSchema=r.object({NewReconnectToken:r.object({token:r.string()})}),a.MessageReceivedSchema=r.object({MessageReceived:r.object({sender_peer_id:r.number(),message:y})}),a.ErrorSchema=r.object({Error:r.object({message:y})}),a.EventSchema=a.PongSchema.or(a.JoinedSchema).or(a.LeftSchema).or(a.PeerJoinedSchema).or(a.PeerLeftSchema).or(a.PeerChangedSchema).or(a.NewReconnectTokenSchema).or(a.MessageReceivedSchema).or(a.ErrorSchema)))(ce||={});import{z as de}from"zod";var U=de.object({sender_peer_id:b,message:y});import*as s from"zod";var v=s.discriminatedUnion("kind",[s.object({kind:s.literal("Sdp"),type:s.enum(["Answer","Offer"]),sdp:s.string(),media_map:s.array(s.tuple([S,s.string()]))}),s.object({kind:s.literal("Trickle"),candidate:s.string(),spd_mid:s.optional(s.string()),spd_mline_index:s.optional(s.number()),username_fragment:s.optional(s.union([s.string(),s.null()]))}),s.object({kind:s.literal("TrickleFinished")})]);import{z as i}from"zod";var $e={Hello:{request:i.object({stream:i.literal("main")}),response:i.null()},JoinRoom:{request:i.object({token:i.string(),room_id:z.RoomIdSchema,user_data:y,position:T}),response:i.object({peer_id:b,stream_id:i.optional(i.number()),token:i.optional(i.string())})},WebRtcUpdate:{request:v,response:i.null()},RequestReconnectToken:{request:i.object({peer_id:i.optional(b)}),response:i.string()},Ping:{request:i.object({}),response:i.null()}},Ge={Hello:{request:i.object({stream:i.literal("room"),token:i.string(),room_id:i.string(),user_data:y,position:T}),response:i.null()},UpdatePeer:{request:i.object({user_data:y}),response:i.null()},StartMedia:{request:i.object({media_id:S,properties:w}),response:i.null()},StopMedia:{request:i.object({media_id:S}),response:i.null()},PauseMedia:{request:i.object({media_id:S}),response:i.null()},ResumeMedia:{request:i.object({media_id:S}),response:i.null()},SetPeerPosition:{request:i.object({position:T}),response:i.null()},SendMessage:{request:i.object({target_peer_ids:i.optional(i.array(b)),message:y}),response:i.null()}};import*as g from"zod";var et=g.object({name:g.literal("WebRtcUpdate"),properties:v}),tt={WebRtcUpdate:v},rt=g.union([g.object({name:g.literal("RoomStatusChanged"),properties:z.RoomStatusChangedSchema}),g.object({name:g.literal("RoomUpdated"),properties:z.RoomUpdatesSchema}),g.object({name:g.literal("PeerUpdated"),properties:M}),g.object({name:g.literal("MessageReceived"),properties:U})]),ot={RoomStatusChanged:z.RoomStatusChangedSchema,RoomUpdated:z.RoomUpdatesSchema,PeerUpdated:M,MessageReceived:U};function R(e,t){e||V(t)}function V(e){throw new Error(e)}function f(e){return{type:"Success",value:e}}function x(e){return{type:"Failure",reason:e}}function it(e){return e.type==="Failure"&&V(e.reason),e.value}function I(e,t){return e.type==="Success"?e.value:t}function pt(e){try{let t=atob(e),o=Uint8Array.from(t,u=>u.codePointAt(0)),d=new TextDecoder("utf8");return f(d.decode(o))}catch(t){return x(String(t))}}function ct(e){try{let t=atob(e.replace(/-/g,"+").replace(/_/g,"/")),o=Uint8Array.from(t,u=>u.codePointAt(0)),d=new TextDecoder("utf8");return f(d.decode(o))}catch(t){return x(String(t))}}function lt(e){try{R(e!==void 0,"undefined cannot be converted to byte array"),R(e!==null,"null cannot be converted to byte array");let t=JSON.stringify(e),o=new TextEncoder;return f(o.encode(t))}catch(t){return x(String(t))}}function mt(e){try{R(e.length>0,"empty byte array cannot be converted to value");let t=new TextDecoder().decode(e),o=JSON.parse(t);return f(o)}catch(t){return x(String(t))}}var ue=["VP8","VP9","AV1","H264"],J=class{constructor(t){this.codec=t}channels=0;clockRate=9e4;isValid(){return ue.includes(this.codec)}isSupported(){if(typeof RTCRtpReceiver>"u"||typeof RTCRtpReceiver.getCapabilities>"u")return null;let t=I(this.getMimeType(),"").toLowerCase(),o=new Set(I(this.getSdpFmtpLine(),"").split(";").map(d=>d.trim().toLowerCase()));return RTCRtpReceiver.getCapabilities("video")?.codecs?.find(d=>{let u=d.mimeType.toLowerCase(),h=new Set((d.sdpFmtpLine??"").split(";").map(n=>n.trim().toLowerCase()));if(t!==u||o.size!==h.size)return!1;for(let n of o)if(!h.has(n))return!1;return!0})??null}getPayloadType(){switch(this.codec){case"VP8":return f(96);case"VP9":return f(98);case"AV1":return f(41);case"H264":return f(102);default:return x("invalid video codec")}}getMimeType(){switch(this.codec){case"VP8":return f("video/VP8");case"VP9":return f("video/VP9");case"AV1":return f("video/AV1");case"H264":return f("video/H264");default:return x("invalid video codec")}}getSdpFmtpLine(){switch(this.codec){case"VP8":return f("");case"VP9":return f("profile-id=2");case"AV1":return f("level-idx=5;profile=0;tier=0");case"H264":return f("level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42e01f");default:return x("invalid video codec")}}};function bt(e,t){for(let o of e)if(t(o))return o}function ht(){return typeof AudioContext<"u"&&typeof Worker<"u"}function St(){return typeof SharedArrayBuffer<"u"}function le(){return/(apple)?webkit\/537\.36/i.test(globalThis.navigator.userAgent)}function zt(){return/electron/i.test(globalThis.navigator.userAgent)}function vt(){return/firefox|iceweasel|fxios/i.test(globalThis.navigator.userAgent)}function kt(){return le()?!1:/safari|applewebkit/i.test(globalThis.navigator.userAgent)}function Tt(e){return JSON.parse(JSON.stringify(e))}var N=class e{constructor(t){this._Generators=t;this._Futures=t.map(e.addIndex)}_Futures;async next(){let[t,o]=await Promise.race(this._Futures);return this._Futures[o]=e.addIndex(this._Generators[o],o),t}static async addIndex(t,o){return[await t(),o]}};function At(e,t){return e<=0?Promise.resolve(t):new Promise(o=>setTimeout(()=>o(t),e))}function wt(e,t){return t.aborted?Promise.resolve("aborted"):new Promise(o=>{let d=()=>o("aborted");t.addEventListener("abort",d,{once:!0}),setTimeout(()=>{t.removeEventListener("abort",d),o(void 0)},e)})}function Lt(){return new Promise(e=>setTimeout(e,0))}var q=class{_Tasks=[];_Running=!1;_Values;constructor(...t){this._Values=t}enqueue(t){return new Promise((o,d)=>{let u=async()=>{try{let h=await t(...this._Values);o(h)}catch(h){d(h)}};this._Tasks.push(u),this._Running||this.execute()})}async execute(){for(this._Running=!0;;){let t=this._Tasks.shift();if(t===void 0)break;await t()}this._Running=!1}};function Ut(e){let t=e.trim();e.indexOf("://")===-1&&(t=`https://${t}`);try{return f(new URL(t))}catch(o){return x(String(o))}}function It(e,t){let o=e.pathname;o.endsWith("/")===!1&&(o+="/");try{return f(new URL(o+t,e))}catch(d){return x(String(d))}}var me=/^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;function Ft(){return crypto.randomUUID()}function Bt(e){return me.test(e)}function Ot(e,t){return t in e}function Vt(e){return typeof e=="function"}function Jt(e){return typeof e=="object"&&e===null}function Nt(e){return typeof e=="number"}function qt(e){return typeof e=="object"}function Wt(e){return typeof e=="string"}function Ht(e){return typeof e>"u"}function $t(e){return e.type==="Failure"}function Gt(e){return e.type==="Success"}var D=(n=>(n[n.Nothing=0]="Nothing",n[n.Error=1]="Error",n[n.Warn=2]="Warn",n[n.Info=3]="Info",n[n.Debug=4]="Debug",n[n.Everything=5]="Everything",n))(D||{}),G=(u=>(u[u.Error=1]="Error",u[u.Warn=2]="Warn",u[u.Info=3]="Info",u[u.Debug=4]="Debug",u))(G||{}),fe={1:"\u{1F534}",2:"\u{1F7E1}",3:"\u{1F535}",4:"\u{1F7E3}"};function Kt(e){for(let t of Object.keys(D))if(isNaN(Number(t))!==!1&&t.localeCompare(e,void 0,{sensitivity:"accent"})===0)return D[t]}function W({message:e}){return String(e)}function H(e){let t=`[${e.date.toISOString()}]`,o=`[${G[e.level]}]`,d=e.logger.name!==void 0?`[${e.logger}] `:"",u=fe[e.level];return`${t} ${u} ${o.padEnd(7," ")} ${d}${e.message}`}var ye={sparse:W,pretty:H,default:Deno.stdout.isTerminal()?H:W},F=class{#e;#t;filter;constructor(t=ye.default,o=5,d=console){this.filter=o,this.#e=t,this.#t=d}handle(t){let o=this.#e(t);switch(t.level){case 1:this.#t.error(o,...t.extra);break;case 2:this.#t.warn(o,...t.extra);break;case 3:this.#t.info(o,...t.extra);break;case 4:this.#t.debug(o,...t.extra);break}}},B=class{#e;sinks;filter;get name(){return this.#e}constructor(t,o=void 0,d=[new F]){this.#e=o,this.sinks=d,this.filter=t}log(t,o,...d){if(this.filter<t)return;let u=$;for(let h of this.sinks)h.filter<t||(u===$&&(u={date:new Date,level:t,logger:this,message:typeof o=="function"?o():o,extra:d}),h.handle(u))}},ge=new B(3);function A(e,t,...o){ge.log(e,t,o)}var Qt=A.bind(void 0,1),Xt=A.bind(void 0,2),Yt=A.bind(void 0,3),er=A.bind(void 0,4),$=Symbol();var rr=-758.596,be;(t=>{let e;(n=>(n[n.InvalidPassword=-1]="InvalidPassword",n[n.Unknown=0]="Unknown",n[n.Unencrypted=1]="Unencrypted",n[n.Encrypted=2]="Encrypted"))(e=t.PeerCipherStatus||={})})(be||={});var or={bytesSent:0,bytesReceived:0,packetsSent:0,packetsReceived:0,rtt:0,packetLoss:0},nr={packetsBuffered:0,packetsSeen:0,packetsProcessed:0,packetsTooEarly:0,packetsTooLate:0,packetsDropped:0,packetsInvalid:0,packetsRepeated:0,packetsLost:0},ir={voiceActivity:{attackThreshold:.9,releaseThreshold:.8},volumeGate:{attackThreshold:-30,releaseThreshold:-40}},ar={echoCanceller:!0,highPassFilter:!1,noiseSuppression:"Moderate",transientSuppressor:!1,gainController:!0};export{ar as APM_DEFAULTS,be as Backend,y as ByteArraySchema,or as CONNECTION_STATS_INITIAL,_ as ChannelSet,O as ChannelSetSchema,F as ConsoleSink,ye as Formatter,ge as GLOBAL_LOGGER,nr as JITTER_STATS_INITIAL,k as JsonSchema,D as LogFilter,G as LogLevel,fe as LogSymbols,B as Logger,$e as MainCommandsRpc,et as MainNotificationSchema,tt as MainNotificationsRpc,se as MediaAudioPropertiesSchema,S as MediaIdSchema,w as MediaPropertiesSchema,L as MediaSchema,pe as MediaVideoPropertiesSchema,Se as MessagePackRpcSchema,U as MessageReceivedSchema,rr as MinDBFS,b as PeerIdSchema,T as PeerPositionSchema,j as PeerSchema,M as PeerUpdateSchema,Ge as RoomCommandsRpc,rt as RoomNotificationSchema,ot as RoomNotificationsRpc,z as RoomV1,ce as RoomV2,N as Selector,q as Strand,ie as TokenAudienceSchema,ke as TokenClaimsSchema,ae as TokenSubjectSchema,ir as VAD_DEFAULTS,J as VideoCodec,v as WebRtcUpdateSchema,wt as abortableSleep,R as assert,er as debug,Qt as error,It as extendUrl,V as fail,x as failure,bt as find,pt as fromBase64,ct as fromBase64Url,mt as fromBytes,Ft as generateUUID,Yt as info,ht as isAudioCapable,le as isBlinkBrowser,zt as isElectronBrowser,$t as isFailure,vt as isFirefoxBrowser,Vt as isFunction,Jt as isNull,Nt as isNumber,qt as isObject,Ot as isProperty,kt as isSafariBrowser,St as isSharedArrayBufferCapable,Wt as isString,Gt as isSuccess,Ht as isUndefined,A as log,Lt as nextTick,Ut as normalizeUrl,P as oneOrMany,At as sleep,f as success,lt as toBytes,Tt as toRaw,Kt as tryParseLogFilter,it as unwrap,I as unwrapOr,Bt as validateUUID,Xt as warn};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@4players/odin-common",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "9.0.0",
|
|
4
4
|
"description": "A collection of commonly used type definitions and utility functions across ODIN web projects",
|
|
5
5
|
"author": "Josho Bleicker <josho.bleicker@4players.io> (https://www.4players.io)",
|
|
6
6
|
"homepage": "https://www.4players.io",
|
package/utility/log.d.ts
CHANGED
|
@@ -1,79 +1,60 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
export declare enum LogFilter {
|
|
2
|
+
Nothing = 0,
|
|
3
|
+
Error = 1,
|
|
4
|
+
Warn = 2,
|
|
5
|
+
Info = 3,
|
|
6
|
+
Debug = 4,
|
|
7
|
+
Everything = 5
|
|
8
|
+
}
|
|
9
|
+
export declare enum LogLevel {
|
|
10
|
+
Error = 1,
|
|
11
|
+
Warn = 2,
|
|
12
|
+
Info = 3,
|
|
13
|
+
Debug = 4
|
|
8
14
|
}
|
|
9
|
-
export type LogLevel = (typeof LogVerbosity)[LogLevelName];
|
|
10
|
-
export type LogLevelName = Exclude<keyof typeof LogVerbosity, number>;
|
|
11
|
-
export declare const LogLevels: LogLevel[];
|
|
12
|
-
export declare const LogLevelNames: LogLevelName[];
|
|
13
15
|
export declare const LogSymbols: {
|
|
14
16
|
[Level in LogLevel]: string;
|
|
15
17
|
};
|
|
16
|
-
export declare
|
|
17
|
-
|
|
18
|
+
export declare function tryParseLogFilter(text: string): LogFilter | undefined;
|
|
19
|
+
export interface LogSink {
|
|
20
|
+
filter: LogFilter;
|
|
21
|
+
handle(record: LogRecord): void;
|
|
22
|
+
}
|
|
23
|
+
export type ConsoleObject = Pick<typeof console, 'error' | 'warn' | 'info' | 'debug'>;
|
|
24
|
+
export type LogFormatter = (record: LogRecord) => string;
|
|
25
|
+
declare function sparseFormat({ message }: LogRecord): string;
|
|
26
|
+
declare function pretty_format(record: LogRecord): string;
|
|
27
|
+
export declare const Formatter: {
|
|
28
|
+
sparse: typeof sparseFormat;
|
|
29
|
+
pretty: typeof pretty_format;
|
|
30
|
+
default: typeof sparseFormat;
|
|
18
31
|
};
|
|
19
|
-
export declare
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
32
|
+
export declare class ConsoleSink implements LogSink {
|
|
33
|
+
#private;
|
|
34
|
+
filter: LogFilter;
|
|
35
|
+
constructor(formatter?: LogFormatter, filter?: LogFilter, consoleObject?: ConsoleObject);
|
|
36
|
+
handle(record: LogRecord): void;
|
|
23
37
|
}
|
|
24
|
-
export declare function getLogger(name?: string): Logger;
|
|
25
|
-
export declare function error<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
26
|
-
export declare function error<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
27
|
-
export declare function warn<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
28
|
-
export declare function warn<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
29
|
-
export declare function info<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
30
|
-
export declare function info<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
31
|
-
export declare function debug<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
32
|
-
export declare function debug<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
33
38
|
export declare class Logger {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
get levelName(): LogLevelName;
|
|
41
|
-
set levelName(value: LogLevelName);
|
|
42
|
-
get handlers(): LogHandler[];
|
|
43
|
-
addHandler(handler: LogHandler): void;
|
|
44
|
-
removeHandler(handler: LogHandler): void;
|
|
45
|
-
log<T>(level: LogLevel, msg: (T extends GenericFunction ? never : T) | (() => T), ...args: unknown[]): T | undefined;
|
|
46
|
-
error<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
47
|
-
error<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
48
|
-
warn<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
49
|
-
warn<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
50
|
-
info<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
51
|
-
info<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
52
|
-
debug<T>(msg: () => T, ...args: unknown[]): T | undefined;
|
|
53
|
-
debug<T>(msg: T extends GenericFunction ? never : T, ...args: unknown[]): T;
|
|
54
|
-
private asString;
|
|
39
|
+
#private;
|
|
40
|
+
sinks: LogSink[];
|
|
41
|
+
filter: LogFilter;
|
|
42
|
+
get name(): string | undefined;
|
|
43
|
+
constructor(filter: LogFilter, name?: string | undefined, sinks?: LogSink[]);
|
|
44
|
+
log(level: LogLevel, message: LogMessage, ...extra: unknown[]): void;
|
|
55
45
|
}
|
|
56
|
-
|
|
57
|
-
type
|
|
46
|
+
export declare const GLOBAL_LOGGER: Logger;
|
|
47
|
+
export type LogMessage = string | (() => unknown);
|
|
48
|
+
export declare function log(level: LogLevel, message: LogMessage, ...extra: unknown[]): void;
|
|
49
|
+
export declare const error: (message: LogMessage, ...extra: unknown[]) => void;
|
|
50
|
+
export declare const warn: (message: LogMessage, ...extra: unknown[]) => void;
|
|
51
|
+
export declare const info: (message: LogMessage, ...extra: unknown[]) => void;
|
|
52
|
+
export declare const debug: (message: LogMessage, ...extra: unknown[]) => void;
|
|
58
53
|
export interface LogRecord {
|
|
59
54
|
readonly date: Date;
|
|
60
55
|
readonly level: LogLevel;
|
|
61
|
-
readonly
|
|
62
|
-
readonly
|
|
63
|
-
readonly
|
|
64
|
-
readonly args: unknown[];
|
|
65
|
-
}
|
|
66
|
-
export declare const DEFAULT_FORMATTER: FormatterFunction;
|
|
67
|
-
export declare const PRETTY_FORMATTER: FormatterFunction;
|
|
68
|
-
export declare class LogHandler {
|
|
69
|
-
private _Level;
|
|
70
|
-
private _FormatterFn;
|
|
71
|
-
constructor(level: LogLevel | LogLevelName, formatter?: FormatterFunction);
|
|
72
|
-
get level(): LogLevel;
|
|
73
|
-
set level(value: LogLevel);
|
|
74
|
-
get levelName(): LogLevelName;
|
|
75
|
-
set levelName(value: LogLevelName);
|
|
76
|
-
handle(record: LogRecord): void;
|
|
77
|
-
log(formattedString: string, record: LogRecord): void;
|
|
56
|
+
readonly logger: Logger;
|
|
57
|
+
readonly message: unknown;
|
|
58
|
+
readonly extra: unknown[];
|
|
78
59
|
}
|
|
79
60
|
export {};
|