diff --git a/.gitmodules b/.gitmodules index 0397080ca..4edba0940 100644 --- a/.gitmodules +++ b/.gitmodules @@ -46,3 +46,9 @@ [submodule "plugins/objectdetector/node-moving-things-tracker"] path = plugins/objectdetector/node-moving-things-tracker url = ../../koush/node-moving-things-tracker.git +[submodule "plugins/tensorflow-lite/src/predict/sort_oh"] + path = plugins/tensorflow-lite/src/predict/sort_oh + url = https://github.com/nonocam/sort_oh.git +[submodule "plugins/tensorflow-lite/sort_oh"] + path = plugins/tensorflow-lite/sort_oh + url = https://github.com/nonocam/sort_oh.git diff --git a/common/src/rtc-signaling.ts b/common/src/rtc-signaling.ts index 46b555561..23e2c586b 100644 --- a/common/src/rtc-signaling.ts +++ b/common/src/rtc-signaling.ts @@ -71,6 +71,7 @@ export class BrowserSignalingSession implements RTCSignalingSession { }, }, screen: { + devicePixelRatio: window.devicePixelRatio, width: screen.width, height: screen.height, }, diff --git a/docker/install-scrypted-dependencies-mac.sh b/docker/install-scrypted-dependencies-mac.sh index d09e57cb2..55dffaefa 100755 --- a/docker/install-scrypted-dependencies-mac.sh +++ b/docker/install-scrypted-dependencies-mac.sh @@ -69,7 +69,7 @@ then fi RUN python$PYTHON_VERSION -m pip install --upgrade pip -RUN python$PYTHON_VERSION -m pip install aiofiles debugpy typing_extensions typing opencv-python +RUN python$PYTHON_VERSION -m pip install aiofiles debugpy typing_extensions typing opencv-python psutil echo "Installing Scrypted Launch Agent..." diff --git a/docker/template/Dockerfile.full.header b/docker/template/Dockerfile.full.header index 851e3c522..2ce241627 100644 --- a/docker/template/Dockerfile.full.header +++ b/docker/template/Dockerfile.full.header @@ -59,7 +59,7 @@ RUN apt-get -y install \ # python pip RUN python3 -m pip install --upgrade pip -RUN python3 -m pip install aiofiles debugpy typing_extensions typing +RUN python3 -m pip install aiofiles debugpy typing_extensions typing psutil ################################################################ # End section generated from template/Dockerfile.full.header diff --git a/docs/plugins/google-home/cast-receiver/js/main.js b/docs/plugins/google-home/cast-receiver/js/main.js index fe04f7430..c60d3303c 100644 --- a/docs/plugins/google-home/cast-receiver/js/main.js +++ b/docs/plugins/google-home/cast-receiver/js/main.js @@ -1,2 +1,2 @@ -(()=>{"use strict";var __webpack_modules__={636:(module,__webpack_exports__,__webpack_require__)=>{function startPeriodicGarbageCollection(){if(__webpack_require__.g.gc)try{const e=__webpack_require__.g;if(e.gc)return setInterval((()=>{e.gc()}),1e4)}catch(e){}else console.warn("rpc peer garbage collection not available: global.gc is not exposed.")}__webpack_require__.d(__webpack_exports__,{uD:()=>RpcPeer}),module=__webpack_require__.hmd(module);class RpcProxy{peer;entry;constructorName;proxyProps;proxyOneWayMethods;constructor(e,t,r,i,o){this.peer=e,this.entry=t,this.constructorName=r,this.proxyProps=i,this.proxyOneWayMethods=o}toPrimitive(){const e=this.peer;return`RpcProxy-${e.selfName}:${e.peerName}: ${this.constructorName}`}get(e,t,r){if(t===RpcPeer.PROPERTY_PROXY_ID)return this.entry.id;if("__proxy_constructor"===t)return this.constructorName;if("__proxy_peer"===t)return this.peer;if(t===RpcPeer.PROPERTY_PROXY_PROPERTIES)return this.proxyProps;if(t===RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS)return this.proxyOneWayMethods;if(t===RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION||t===RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN)return;if("then"===t)return;if("constructor"===t)return;if(void 0!==this.proxyProps?.[t])return this.proxyProps?.[t];return RpcPeer.handleFunctionInvocations(this,e,t,r)||new Proxy((()=>t),this)}set(e,t,r,i){return t===RpcPeer.finalizerIdSymbol&&(this.entry.finalizerId=r),!0}apply(e,t,r){if(Object.isFrozen(this.peer.pendingResults))return Promise.reject(new RPCResultError(this.peer,"RpcPeer has been killed"));const i=e()||null,o=[],n={};for(const e of r||[])o.push(this.peer.serialize(e,n));const s={type:"apply",id:void 0,proxyId:this.entry.id,args:o,method:i};return this.proxyOneWayMethods?.includes?.(i)?(s.oneway=!0,this.peer.send(s,void 0,n),Promise.resolve()):this.peer.createPendingResult(((e,t)=>{s.id=e,this.peer.send(s,t,n)}))}}class RPCResultError extends Error{cause;constructor(e,t,r,i){super(`${e.selfName}:${e.peerName}: ${t}`),this.cause=r,i?.name&&(this.name=i?.name),i?.stack&&(this.stack=`${e.peerName}:${e.selfName}\n${r?.stack||i.stack}`)}}function compileFunction(code,params,options){params=params||[];const f=`(function(${params.join(",")}) {;${code};})`;return eval(f)}try{const e=FinalizationRegistry}catch(e){window.WeakRef=class{target;constructor(e){this.target=e}deref(){return this.target}},window.FinalizationRegistry=class{register(){}}}class RpcPeer{selfName;peerName;send;idCounter=1;params={};pendingResults={};proxyCounter=1;localProxied=new Map;localProxyMap={};remoteWeakProxies={};finalizers=new FinalizationRegistry((e=>this.finalize(e)));nameDeserializerMap=new Map;constructorSerializerMap=new Map;transportSafeArgumentTypes=RpcPeer.getDefaultTransportSafeArgumentTypes();killed;killedDeferred;static finalizerIdSymbol=Symbol("rpcFinalizerId");static isRpcProxy(e){return!!e?.[RpcPeer.PROPERTY_PROXY_ID]}static getDefaultTransportSafeArgumentTypes(){const e=new Set;return e.add(Number.name),e.add(String.name),e.add(Object.name),e.add(Boolean.name),e.add(Array.name),e}static handleFunctionInvocations(e,t,r,i){return"apply"===r?(r,i)=>e.apply(t,e,i):"call"===r?(r,...i)=>e.apply(t,e,i):"toString"===r||r===Symbol.toPrimitive?(t,...r)=>e.toPrimitive():void 0}static PROPERTY_PROXY_ID="__proxy_id";static PROPERTY_PROXY_ONEWAY_METHODS="__proxy_oneway_methods";static PROPERTY_JSON_DISABLE_SERIALIZATION="__json_disable_serialization";static PROPERTY_PROXY_PROPERTIES="__proxy_props";static PROPERTY_JSON_COPY_SERIALIZE_CHILDREN="__json_copy_serialize_children";static PROBED_PROPERTIES=new Set(["then","constructor","__proxy_id","__proxy_constructor","__proxy_peer",RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS,RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION,RpcPeer.PROPERTY_PROXY_PROPERTIES,RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN]);constructor(e,t,r){this.selfName=e,this.peerName=t,this.send=r,this.killed=new Promise(((e,t)=>{this.killedDeferred={resolve:e,reject:t}}))}createPendingResult(e){if(Object.isFrozen(this.pendingResults))return Promise.reject(new RPCResultError(this,"RpcPeer has been killed"));const t=new Promise(((t,r)=>{const i=(this.idCounter++).toString();this.pendingResults[i]={resolve:t,reject:r},e(i,(e=>r(new RPCResultError(this,e.message,e))))}));return t.catch((()=>{})),t}kill(e){const t=new RPCResultError(this,e||"peer was killed");this.killedDeferred.reject(t);for(const e of Object.values(this.pendingResults))e.reject(t);this.pendingResults=Object.freeze({}),this.params=Object.freeze({}),this.remoteWeakProxies=Object.freeze({}),this.localProxyMap=Object.freeze({}),this.localProxied.clear()}addSerializer(e,t,r){this.nameDeserializerMap.set(t,r),this.constructorSerializerMap.set(e,t)}finalize(e){delete this.remoteWeakProxies[e.id];const t={__local_proxy_id:e.id,__local_proxy_finalizer_id:e.finalizerId,type:"finalize"};this.send(t)}async getParam(e){return this.createPendingResult(((t,r)=>{const i={id:t,type:"param",param:e};this.send(i,r)}))}evalLocal(e,t,r){const i=Object.assign({},this.params,r);let o;try{o=module.require("vm").compileFunction}catch(e){o=compileFunction}return o(e,Object.keys(i),{filename:t})(...Object.values(i))}createErrorResult(e,t){e.stack=t.stack||"no stack",e.result=t.name||"no name",e.message=t.message||"no message"}deserialize(e,t){if(!e)return e;if(e[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN]){const r={};for(const[i,o]of Object.entries(e))r[i]=this.deserialize(o,t);return r}const{__remote_proxy_id:r,__remote_proxy_finalizer_id:i,__local_proxy_id:o,__remote_constructor_name:n,__serialized_value:s,__remote_proxy_props:a,__remote_proxy_oneway_methods:c}=e;if(r){let e=this.remoteWeakProxies[r]?.deref();return e||(e=this.newProxy(r,n,a,c)),e[RpcPeer.finalizerIdSymbol]=i,e}if(o){const e=this.localProxyMap[o];if(!e)throw new RPCResultError(this,`invalid local proxy id ${o}`);return e}const _=this.nameDeserializerMap.get(n);return _?_.deserialize(s,t):e}serialize(e,t){if(!0===e?.[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN]){const r={};for(const[i,o]of Object.entries(e))r[i]=this.serialize(o,t);return r}if(!e||!e[RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION]&&this.transportSafeArgumentTypes.has(e.constructor?.name))return e;let r=e.__proxy_constructor||e.constructor?.name?.toString(),i=this.localProxied.get(e);if(i){const t=(this.proxyCounter++).toString();return i.finalizerId=t,{__remote_proxy_id:i.id,__remote_proxy_finalizer_id:t,__remote_constructor_name:r,__remote_proxy_props:e?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],__remote_proxy_oneway_methods:e?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS]}}const{__proxy_id:o,__proxy_peer:n}=e;if(o&&n===this)return{__local_proxy_id:o};const s=this.constructorSerializerMap.get(e.constructor);if(s){r=s;const i=this.nameDeserializerMap.get(s);if(!i)throw new Error("serializer not found for "+s);const o=i.serialize(e,t);return{__remote_proxy_id:void 0,__remote_proxy_finalizer_id:void 0,__remote_constructor_name:r,__remote_proxy_props:e?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],__remote_proxy_oneway_methods:e?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],__serialized_value:o}}const a=(this.proxyCounter++).toString();return i={id:a,finalizerId:a},this.localProxied.set(e,i),this.localProxyMap[a]=e,{__remote_proxy_id:a,__remote_proxy_finalizer_id:a,__remote_constructor_name:r,__remote_proxy_props:e?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],__remote_proxy_oneway_methods:e?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS]}}newProxy(e,t,r,i){const o={id:e,finalizerId:void 0},n=new RpcProxy(this,o,t,r,i),s=new Proxy("Function"===t||"AsyncFunction"===t?function(){}:n,n),a=new WeakRef(s);return this.remoteWeakProxies[e]=a,this.finalizers.register(n,o),s}async handleMessage(e,t){try{switch(e.type){case"param":{const t=e,r={},i={type:"result",id:t.id,result:this.serialize(this.params[t.param],r)};this.send(i,void 0,r);break}case"apply":{const r=e,i={type:"result",id:r.id||""},o={};try{const e=this.localProxyMap[r.proxyId];if(!e)throw new Error(`proxy id ${r.proxyId} not found`);const n=[];for(const e of r.args||[])n.push(this.deserialize(e,t));let s;if(r.method){if(!e[r.method])throw new Error(`target ${e?.constructor?.name} does not have method ${r.method}`);s=await e[r.method](...n)}else s=await e(...n);i.result=this.serialize(s,o)}catch(e){this.createErrorResult(i,e)}r.oneway||this.send(i,void 0,o);break}case"result":{const r=e,i=this.pendingResults[r.id];if(delete this.pendingResults[r.id],!i)throw new Error(`unknown result ${r.id}`);if(r.message||r.stack){const e=new RPCResultError(this,r.message||"no message",void 0,{name:r.result,stack:r.stack});return void i.reject(e)}i.resolve(this.deserialize(r.result,t));break}case"finalize":{const t=e,r=this.localProxyMap[t.__local_proxy_id];if(r){const e=this.localProxied.get(r);if(t.__local_proxy_finalizer_id&&t.__local_proxy_finalizer_id!==e?.finalizerId)break;delete this.localProxyMap[t.__local_proxy_id],this.localProxied.delete(r)}break}default:throw new Error(`unknown rpc message type ${e.type}`)}}catch(e){return void console.error("unhandled rpc error",this.peerName,e)}}}function getEvalSource(){return`\n (() => {\n ${RpcProxy}\n\n ${RpcPeer}\n \n return {\n RpcPeer,\n RpcProxy,\n };\n })();\n `}}},__webpack_module_cache__={};function __webpack_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var r=__webpack_module_cache__[e]={id:e,loaded:!1,exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.loaded=!0,r.exports}__webpack_require__.d=(e,t)=>{for(var r in t)__webpack_require__.o(t,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.hmd=e=>((e=Object.create(e)).children||(e.children=[]),Object.defineProperty(e,"exports",{enumerable:!0,set:()=>{throw new Error("ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: "+e.id)}}),e),__webpack_require__.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);var __webpack_exports__={};(()=>{var e=__webpack_require__(636);class t{finished=!1;resolve;reject;promise=new Promise(((e,t)=>{this.resolve=t=>{this.finished=!0,e(t)},this.reject=e=>{this.finished=!0,t(e)}}))}function r(){try{return navigator.userAgent}catch(e){}}function i(e){return new Promise((t=>{e.addEventListener("iceconnectionstatechange",(()=>{o(e)&&t(e.iceConnectionState)}))}))}function o(e){return"disconnected"===e.iceConnectionState||"failed"===e.iceConnectionState||"closed"===e.iceConnectionState}class n{pc;pcDeferred=new t;dcDeferred=new t;microphone;micEnabled=!1;onPeerConnection;options={userAgent:r(),capabilities:{audio:RTCRtpReceiver.getCapabilities?.("audio")||{codecs:void 0,headerExtensions:void 0},video:RTCRtpReceiver.getCapabilities?.("video")||{codecs:void 0,headerExtensions:void 0}},screen:{width:screen.width,height:screen.height}};constructor(){}async getOptions(){return this.options}async setMicrophone(e){if(this.microphone&&e&&!this.micEnabled){this.micEnabled=!0;const e=await navigator.mediaDevices.getUserMedia({video:!1,audio:!0});await this.microphone.replaceTrack(e.getTracks()[0])}this.microphone.track.enabled=e}close(){this.pcDeferred.promise.then((e=>{for(const t of e.getTransceivers()||[])try{t.sender?.track?.stop?.()}catch(e){}e.close()})).catch((()=>{})),this.pcDeferred.reject(new Error("iceConnectionState "+this.pc?.iceConnectionState))}async createPeerConnection(e){if(this.pc)return;const t=this.pc=new RTCPeerConnection(e.configuration);if(this.pcDeferred.resolve(t),await(this.onPeerConnection?.(t)),t.addEventListener("iceconnectionstatechange",(()=>{console.log("iceConnectionState",t.iceConnectionState),console.log("connectionState",t.connectionState),o(t)&&this.close()})),e.datachannel){const r=t.createDataChannel(e.datachannel.label,e.datachannel.dict);r.binaryType="arraybuffer",this.dcDeferred.resolve(r)}if(e.audio){const r=t.addTransceiver("audio",e.audio);"sendrecv"!==e.audio.direction&&"sendonly"!==e.audio.direction||(this.microphone=r.sender)}if(e.video)if("sendrecv"===e.video.direction||"sendonly"===e.video.direction)try{const e=await navigator.mediaDevices.getUserMedia({video:!0});for(const r of e.getTracks())t.addTrack(r)}catch(e){}else t.addTransceiver("video",e.video)}async createLocalDescription(e,t,r){await this.createPeerConnection(t);const i=new Promise((e=>{this.pc.onicecandidate=t=>{t.candidate?r?.(JSON.parse(JSON.stringify(t.candidate))):e(void 0)},this.pc.onicegatheringstatechange=()=>{"complete"===this.pc.iceGatheringState&&e(void 0)}})),o=e=>({type:e.type,sdp:e.sdp});if("offer"===e){let e=await this.pc.createOffer({offerToReceiveAudio:!!t.audio,offerToReceiveVideo:!!t.video});const n=this.pc.setLocalDescription(e);return r||(await n,await i,e=await this.pc.createOffer({offerToReceiveAudio:!!t.audio,offerToReceiveVideo:!!t.video})),o(e)}{let e=await this.pc.createAnswer();const t=this.pc.setLocalDescription(e);return r||(await t,await i,e=this.pc.currentLocalDescription||e),o(e)}}async setRemoteDescription(e,t){await this.createPeerConnection(t),await this.pc.setRemoteDescription(e)}async addIceCandidate(e){await this.pc.addIceCandidate(e)}async endSession(){}}document.addEventListener("DOMContentLoaded",(function(t){const r=new cast.framework.CastReceiverOptions;r.disableIdleTimeout=!0,cast.framework.CastReceiverContext.getInstance().start(r);const o=cast.framework.CastReceiverContext.getInstance().getPlayerManager(),s=document.getElementById("media");let a;o.setMessageInterceptor(cast.framework.messages.MessageType.LOAD,(t=>{console.log(t);const r=t.media.entity||t.media.contentId,o=t.credentials??t.media.customData.token,c=new URL(r),_=c.pathname,d={};for(const[e,t]of new URLSearchParams(c.search))d[e]=t;const p={path:_,query:d},l=eio(`wss://${c.host}`,p);return l.on("open",(async()=>{l.send(JSON.stringify({token:o}));const t=new e.uD("cast-receiver","host",((e,t)=>{try{l.send(JSON.stringify(e))}catch(e){t?.(e)}}));l.on("message",(e=>{t.handleMessage(JSON.parse(e))}));const r=new n,c=()=>{console.log("cleanup"),l.close(),r.pcDeferred.promise.then((e=>e.close()))};a?.(),a=c,l.on("close",(()=>{console.log("socket io connection close event"),c()})),r.onPeerConnection=async e=>{i(e).then(c);const t=new MediaStream(e.getReceivers().map((e=>e.track)));e.ontrack=e=>t.addTrack(e.track),s.srcObject=t,function(e){return new Promise(((t,r)=>{"connected"!==e.iceConnectionState?(e.addEventListener("iceconnectionstatechange",(()=>{"connected"===e.iceConnectionState&&t(void 0)})),i(e).then((e=>r(new Error(e))))):t(void 0)}))}(e).then((()=>{l.removeAllListeners()}))},t.params.session=r})),null}))}))})()})(); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","mappings":"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","sources":["webpack:///./dist/server/src/rpc.js","webpack:///webpack/bootstrap","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/global","webpack:///webpack/runtime/harmony module decorator","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///./dist/common/src/deferred.js","webpack:///./dist/common/src/rtc-signaling.js","webpack:///./dist/docs/plugins/google-home/cast-receiver/src/cast.js"],"sourcesContent":["export function startPeriodicGarbageCollection() {\n    if (!global.gc) {\n        console.warn('rpc peer garbage collection not available: global.gc is not exposed.');\n        return;\n    }\n    try {\n        const g = global;\n        if (g.gc) {\n            return setInterval(() => {\n                g.gc();\n            }, 10000);\n        }\n    }\n    catch (e) {\n    }\n}\nclass RpcProxy {\n    peer;\n    entry;\n    constructorName;\n    proxyProps;\n    proxyOneWayMethods;\n    constructor(peer, entry, constructorName, proxyProps, proxyOneWayMethods) {\n        this.peer = peer;\n        this.entry = entry;\n        this.constructorName = constructorName;\n        this.proxyProps = proxyProps;\n        this.proxyOneWayMethods = proxyOneWayMethods;\n    }\n    toPrimitive() {\n        const peer = this.peer;\n        return `RpcProxy-${peer.selfName}:${peer.peerName}: ${this.constructorName}`;\n    }\n    get(target, p, receiver) {\n        if (p === RpcPeer.PROPERTY_PROXY_ID)\n            return this.entry.id;\n        if (p === '__proxy_constructor')\n            return this.constructorName;\n        if (p === '__proxy_peer')\n            return this.peer;\n        if (p === RpcPeer.PROPERTY_PROXY_PROPERTIES)\n            return this.proxyProps;\n        if (p === RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS)\n            return this.proxyOneWayMethods;\n        if (p === RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION || p === RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN)\n            return;\n        if (p === 'then')\n            return;\n        if (p === 'constructor')\n            return;\n        if (this.proxyProps?.[p] !== undefined)\n            return this.proxyProps?.[p];\n        const handled = RpcPeer.handleFunctionInvocations(this, target, p, receiver);\n        if (handled)\n            return handled;\n        return new Proxy(() => p, this);\n    }\n    set(target, p, value, receiver) {\n        if (p === RpcPeer.finalizerIdSymbol)\n            this.entry.finalizerId = value;\n        return true;\n    }\n    apply(target, thisArg, argArray) {\n        if (Object.isFrozen(this.peer.pendingResults))\n            return Promise.reject(new RPCResultError(this.peer, 'RpcPeer has been killed'));\n        // rpc objects can be functions. if the function is a oneway method,\n        // it will have a null in the oneway method list. this is because\n        // undefined is not JSON serializable.\n        const method = target() || null;\n        const args = [];\n        const serializationContext = {};\n        for (const arg of (argArray || [])) {\n            args.push(this.peer.serialize(arg, serializationContext));\n        }\n        const rpcApply = {\n            type: \"apply\",\n            id: undefined,\n            proxyId: this.entry.id,\n            args,\n            method,\n        };\n        if (this.proxyOneWayMethods?.includes?.(method)) {\n            rpcApply.oneway = true;\n            this.peer.send(rpcApply, undefined, serializationContext);\n            return Promise.resolve();\n        }\n        return this.peer.createPendingResult((id, reject) => {\n            rpcApply.id = id;\n            this.peer.send(rpcApply, reject, serializationContext);\n        });\n    }\n}\n// todo: error constructor adds a \"cause\" variable in Chrome 93, Node v??\nexport class RPCResultError extends Error {\n    cause;\n    constructor(peer, message, cause, options) {\n        super(`${peer.selfName}:${peer.peerName}: ${message}`);\n        this.cause = cause;\n        if (options?.name) {\n            this.name = options?.name;\n        }\n        if (options?.stack) {\n            this.stack = `${peer.peerName}:${peer.selfName}\\n${cause?.stack || options.stack}`;\n        }\n    }\n}\nfunction compileFunction(code, params, options) {\n    params = params || [];\n    const f = `(function(${params.join(',')}) {;${code};})`;\n    return eval(f);\n}\ntry {\n    const fr = FinalizationRegistry;\n}\ncatch (e) {\n    window.WeakRef = class WeakRef {\n        target;\n        constructor(target) {\n            this.target = target;\n        }\n        deref() {\n            return this.target;\n        }\n    };\n    window.FinalizationRegistry = class FinalizationRegistry {\n        register() {\n        }\n    };\n}\nexport class RpcPeer {\n    selfName;\n    peerName;\n    send;\n    idCounter = 1;\n    params = {};\n    pendingResults = {};\n    proxyCounter = 1;\n    localProxied = new Map();\n    localProxyMap = {};\n    remoteWeakProxies = {};\n    finalizers = new FinalizationRegistry(entry => this.finalize(entry));\n    nameDeserializerMap = new Map();\n    constructorSerializerMap = new Map();\n    transportSafeArgumentTypes = RpcPeer.getDefaultTransportSafeArgumentTypes();\n    killed;\n    killedDeferred;\n    static finalizerIdSymbol = Symbol('rpcFinalizerId');\n    static isRpcProxy(value) {\n        return !!value?.[RpcPeer.PROPERTY_PROXY_ID];\n    }\n    static getDefaultTransportSafeArgumentTypes() {\n        const jsonSerializable = new Set();\n        jsonSerializable.add(Number.name);\n        jsonSerializable.add(String.name);\n        jsonSerializable.add(Object.name);\n        jsonSerializable.add(Boolean.name);\n        jsonSerializable.add(Array.name);\n        return jsonSerializable;\n    }\n    static handleFunctionInvocations(thiz, target, p, receiver) {\n        if (p === 'apply') {\n            return (thisArg, args) => {\n                return thiz.apply(target, thiz, args);\n            };\n        }\n        else if (p === 'call') {\n            return (thisArg, ...args) => {\n                return thiz.apply(target, thiz, args);\n            };\n        }\n        else if (p === 'toString' || p === Symbol.toPrimitive) {\n            return (thisArg, ...args) => {\n                return thiz.toPrimitive();\n            };\n        }\n    }\n    static PROPERTY_PROXY_ID = '__proxy_id';\n    static PROPERTY_PROXY_ONEWAY_METHODS = '__proxy_oneway_methods';\n    static PROPERTY_JSON_DISABLE_SERIALIZATION = '__json_disable_serialization';\n    static PROPERTY_PROXY_PROPERTIES = '__proxy_props';\n    static PROPERTY_JSON_COPY_SERIALIZE_CHILDREN = '__json_copy_serialize_children';\n    static PROBED_PROPERTIES = new Set([\n        'then',\n        'constructor',\n        '__proxy_id',\n        '__proxy_constructor',\n        '__proxy_peer',\n        RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS,\n        RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION,\n        RpcPeer.PROPERTY_PROXY_PROPERTIES,\n        RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN,\n    ]);\n    constructor(selfName, peerName, send) {\n        this.selfName = selfName;\n        this.peerName = peerName;\n        this.send = send;\n        this.killed = new Promise((resolve, reject) => {\n            this.killedDeferred = { resolve, reject };\n        });\n    }\n    createPendingResult(cb) {\n        if (Object.isFrozen(this.pendingResults))\n            return Promise.reject(new RPCResultError(this, 'RpcPeer has been killed'));\n        const promise = new Promise((resolve, reject) => {\n            const id = (this.idCounter++).toString();\n            this.pendingResults[id] = { resolve, reject };\n            cb(id, e => reject(new RPCResultError(this, e.message, e)));\n        });\n        // todo: make this an option so rpc doesn't nuke the process if uncaught?\n        promise.catch(() => { });\n        return promise;\n    }\n    kill(message) {\n        const error = new RPCResultError(this, message || 'peer was killed');\n        this.killedDeferred.reject(error);\n        for (const result of Object.values(this.pendingResults)) {\n            result.reject(error);\n        }\n        this.pendingResults = Object.freeze({});\n        this.params = Object.freeze({});\n        this.remoteWeakProxies = Object.freeze({});\n        this.localProxyMap = Object.freeze({});\n        this.localProxied.clear();\n    }\n    // need a name/constructor map due to babel name mangling? fix somehow?\n    addSerializer(ctr, name, serializer) {\n        this.nameDeserializerMap.set(name, serializer);\n        this.constructorSerializerMap.set(ctr, name);\n    }\n    finalize(entry) {\n        delete this.remoteWeakProxies[entry.id];\n        const rpcFinalize = {\n            __local_proxy_id: entry.id,\n            __local_proxy_finalizer_id: entry.finalizerId,\n            type: 'finalize',\n        };\n        this.send(rpcFinalize);\n    }\n    async getParam(param) {\n        return this.createPendingResult((id, reject) => {\n            const paramMessage = {\n                id,\n                type: 'param',\n                param,\n            };\n            this.send(paramMessage, reject);\n        });\n    }\n    evalLocal(script, filename, coercedParams) {\n        const params = Object.assign({}, this.params, coercedParams);\n        let compile;\n        try {\n            // prevent bundlers from trying to include non-existent vm module.\n            compile = module[`require`]('vm').compileFunction;\n        }\n        catch (e) {\n            compile = compileFunction;\n        }\n        const f = compile(script, Object.keys(params), {\n            filename,\n        });\n        const value = f(...Object.values(params));\n        return value;\n    }\n    createErrorResult(result, e) {\n        result.stack = e.stack || 'no stack';\n        result.result = e.name || 'no name';\n        result.message = e.message || 'no message';\n    }\n    deserialize(value, deserializationContext) {\n        if (!value)\n            return value;\n        const copySerializeChildren = value[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN];\n        if (copySerializeChildren) {\n            const ret = {};\n            for (const [key, val] of Object.entries(value)) {\n                ret[key] = this.deserialize(val, deserializationContext);\n            }\n            return ret;\n        }\n        const { __remote_proxy_id, __remote_proxy_finalizer_id, __local_proxy_id, __remote_constructor_name, __serialized_value, __remote_proxy_props, __remote_proxy_oneway_methods } = value;\n        if (__remote_proxy_id) {\n            let proxy = this.remoteWeakProxies[__remote_proxy_id]?.deref();\n            if (!proxy)\n                proxy = this.newProxy(__remote_proxy_id, __remote_constructor_name, __remote_proxy_props, __remote_proxy_oneway_methods);\n            proxy[RpcPeer.finalizerIdSymbol] = __remote_proxy_finalizer_id;\n            return proxy;\n        }\n        if (__local_proxy_id) {\n            const ret = this.localProxyMap[__local_proxy_id];\n            if (!ret)\n                throw new RPCResultError(this, `invalid local proxy id ${__local_proxy_id}`);\n            return ret;\n        }\n        const deserializer = this.nameDeserializerMap.get(__remote_constructor_name);\n        if (deserializer) {\n            return deserializer.deserialize(__serialized_value, deserializationContext);\n        }\n        return value;\n    }\n    serialize(value, serializationContext) {\n        if (value?.[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN] === true) {\n            const ret = {};\n            for (const [key, val] of Object.entries(value)) {\n                ret[key] = this.serialize(val, serializationContext);\n            }\n            return ret;\n        }\n        if (!value || (!value[RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION] && this.transportSafeArgumentTypes.has(value.constructor?.name))) {\n            return value;\n        }\n        let __remote_constructor_name = value.__proxy_constructor || value.constructor?.name?.toString();\n        let proxiedEntry = this.localProxied.get(value);\n        if (proxiedEntry) {\n            const __remote_proxy_finalizer_id = (this.proxyCounter++).toString();\n            proxiedEntry.finalizerId = __remote_proxy_finalizer_id;\n            const ret = {\n                __remote_proxy_id: proxiedEntry.id,\n                __remote_proxy_finalizer_id,\n                __remote_constructor_name,\n                __remote_proxy_props: value?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],\n                __remote_proxy_oneway_methods: value?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],\n            };\n            return ret;\n        }\n        const { __proxy_id, __proxy_peer } = value;\n        if (__proxy_id && __proxy_peer === this) {\n            const ret = {\n                __local_proxy_id: __proxy_id,\n            };\n            return ret;\n        }\n        const serializerMapName = this.constructorSerializerMap.get(value.constructor);\n        if (serializerMapName) {\n            __remote_constructor_name = serializerMapName;\n            const serializer = this.nameDeserializerMap.get(serializerMapName);\n            if (!serializer)\n                throw new Error('serializer not found for ' + serializerMapName);\n            const serialized = serializer.serialize(value, serializationContext);\n            const ret = {\n                __remote_proxy_id: undefined,\n                __remote_proxy_finalizer_id: undefined,\n                __remote_constructor_name,\n                __remote_proxy_props: value?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],\n                __remote_proxy_oneway_methods: value?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],\n                __serialized_value: serialized,\n            };\n            return ret;\n        }\n        const __remote_proxy_id = (this.proxyCounter++).toString();\n        proxiedEntry = {\n            id: __remote_proxy_id,\n            finalizerId: __remote_proxy_id,\n        };\n        this.localProxied.set(value, proxiedEntry);\n        this.localProxyMap[__remote_proxy_id] = value;\n        const ret = {\n            __remote_proxy_id,\n            __remote_proxy_finalizer_id: __remote_proxy_id,\n            __remote_constructor_name,\n            __remote_proxy_props: value?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],\n            __remote_proxy_oneway_methods: value?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],\n        };\n        return ret;\n    }\n    newProxy(proxyId, proxyConstructorName, proxyProps, proxyOneWayMethods) {\n        const localProxiedEntry = {\n            id: proxyId,\n            finalizerId: undefined,\n        };\n        const rpc = new RpcProxy(this, localProxiedEntry, proxyConstructorName, proxyProps, proxyOneWayMethods);\n        const target = proxyConstructorName === 'Function' || proxyConstructorName === 'AsyncFunction' ? function () { } : rpc;\n        const proxy = new Proxy(target, rpc);\n        const weakref = new WeakRef(proxy);\n        this.remoteWeakProxies[proxyId] = weakref;\n        this.finalizers.register(rpc, localProxiedEntry);\n        return proxy;\n    }\n    async handleMessage(message, deserializationContext) {\n        try {\n            switch (message.type) {\n                case 'param': {\n                    const rpcParam = message;\n                    const serializationContext = {};\n                    const result = {\n                        type: 'result',\n                        id: rpcParam.id,\n                        result: this.serialize(this.params[rpcParam.param], serializationContext)\n                    };\n                    this.send(result, undefined, serializationContext);\n                    break;\n                }\n                case 'apply': {\n                    const rpcApply = message;\n                    const result = {\n                        type: 'result',\n                        id: rpcApply.id || '',\n                    };\n                    const serializationContext = {};\n                    try {\n                        const target = this.localProxyMap[rpcApply.proxyId];\n                        if (!target)\n                            throw new Error(`proxy id ${rpcApply.proxyId} not found`);\n                        const args = [];\n                        for (const arg of (rpcApply.args || [])) {\n                            args.push(this.deserialize(arg, deserializationContext));\n                        }\n                        let value;\n                        if (rpcApply.method) {\n                            const method = target[rpcApply.method];\n                            if (!method)\n                                throw new Error(`target ${target?.constructor?.name} does not have method ${rpcApply.method}`);\n                            value = await target[rpcApply.method](...args);\n                        }\n                        else {\n                            value = await target(...args);\n                        }\n                        result.result = this.serialize(value, serializationContext);\n                    }\n                    catch (e) {\n                        // console.error('failure', rpcApply.method, e);\n                        this.createErrorResult(result, e);\n                    }\n                    if (!rpcApply.oneway)\n                        this.send(result, undefined, serializationContext);\n                    break;\n                }\n                case 'result': {\n                    const rpcResult = message;\n                    const deferred = this.pendingResults[rpcResult.id];\n                    delete this.pendingResults[rpcResult.id];\n                    if (!deferred)\n                        throw new Error(`unknown result ${rpcResult.id}`);\n                    if (rpcResult.message || rpcResult.stack) {\n                        const e = new RPCResultError(this, rpcResult.message || 'no message', undefined, {\n                            name: rpcResult.result,\n                            stack: rpcResult.stack,\n                        });\n                        deferred.reject(e);\n                        return;\n                    }\n                    deferred.resolve(this.deserialize(rpcResult.result, deserializationContext));\n                    break;\n                }\n                case 'finalize': {\n                    const rpcFinalize = message;\n                    const local = this.localProxyMap[rpcFinalize.__local_proxy_id];\n                    if (local) {\n                        const localProxiedEntry = this.localProxied.get(local);\n                        // if a finalizer id is specified, it must match.\n                        if (rpcFinalize.__local_proxy_finalizer_id && rpcFinalize.__local_proxy_finalizer_id !== localProxiedEntry?.finalizerId) {\n                            break;\n                        }\n                        delete this.localProxyMap[rpcFinalize.__local_proxy_id];\n                        this.localProxied.delete(local);\n                    }\n                    break;\n                }\n                default:\n                    throw new Error(`unknown rpc message type ${message.type}`);\n            }\n        }\n        catch (e) {\n            console.error('unhandled rpc error', this.peerName, e);\n            return;\n        }\n    }\n}\nexport function getEvalSource() {\n    return `\n    (() => {\n        ${RpcProxy}\n\n        ${RpcPeer}\n    \n        return {\n            RpcPeer,\n            RpcProxy,\n        };\n    })();\n    `;\n}\n//# sourceMappingURL=rpc.js.map","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.hmd = (module) => {\n\tmodule = Object.create(module);\n\tif (!module.children) module.children = [];\n\tObject.defineProperty(module, 'exports', {\n\t\tenumerable: true,\n\t\tset: () => {\n\t\t\tthrow new Error('ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: ' + module.id);\n\t\t}\n\t});\n\treturn module;\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","export class Deferred {\n    finished = false;\n    resolve;\n    reject;\n    promise = new Promise((resolve, reject) => {\n        this.resolve = v => {\n            this.finished = true;\n            resolve(v);\n        };\n        this.reject = e => {\n            this.finished = true;\n            reject(e);\n        };\n    });\n}\n//# sourceMappingURL=deferred.js.map","import { Deferred } from \"./deferred\";\nfunction getUserAgent() {\n    try {\n        return navigator.userAgent;\n    }\n    catch (e) {\n    }\n}\n// connectionState is not implemented in firefox? so watch iceConnectionState instead...\nexport function waitPeerConnectionIceConnected(pc) {\n    return new Promise((resolve, reject) => {\n        if (pc.iceConnectionState === 'connected') {\n            resolve(undefined);\n            return;\n        }\n        pc.addEventListener('iceconnectionstatechange', () => {\n            if (pc.iceConnectionState === 'connected')\n                resolve(undefined);\n        });\n        waitPeerIceConnectionClosed(pc).then(reason => reject(new Error(reason)));\n    });\n}\nexport function waitPeerIceConnectionClosed(pc) {\n    return new Promise(resolve => {\n        pc.addEventListener('iceconnectionstatechange', () => {\n            if (isPeerConnectionClosed(pc)) {\n                resolve(pc.iceConnectionState);\n            }\n        });\n    });\n}\nexport function isPeerConnectionClosed(pc) {\n    return pc.iceConnectionState === 'disconnected'\n        || pc.iceConnectionState === 'failed'\n        || pc.iceConnectionState === 'closed';\n}\nfunction silence() {\n    let ctx = new AudioContext(), oscillator = ctx.createOscillator();\n    const dest = ctx.createMediaStreamDestination();\n    oscillator.connect(dest);\n    oscillator.start();\n    const ret = dest.stream.getAudioTracks()[0];\n    ret.enabled = false;\n    return ret;\n}\nexport class BrowserSignalingSession {\n    pc;\n    pcDeferred = new Deferred();\n    dcDeferred = new Deferred();\n    microphone;\n    micEnabled = false;\n    onPeerConnection;\n    options = {\n        userAgent: getUserAgent(),\n        capabilities: {\n            audio: RTCRtpReceiver.getCapabilities?.('audio') || {\n                codecs: undefined,\n                headerExtensions: undefined,\n            },\n            video: RTCRtpReceiver.getCapabilities?.('video') || {\n                codecs: undefined,\n                headerExtensions: undefined,\n            },\n        },\n        screen: {\n            width: screen.width,\n            height: screen.height,\n        },\n    };\n    constructor() {\n    }\n    async getOptions() {\n        return this.options;\n    }\n    async setMicrophone(enabled) {\n        if (this.microphone && enabled && !this.micEnabled) {\n            this.micEnabled = true;\n            // doing sendrecv on safari requires a mic be attached, or it fails to connect.\n            const mic = await navigator.mediaDevices.getUserMedia({ video: false, audio: true });\n            await this.microphone.replaceTrack(mic.getTracks()[0]);\n        }\n        this.microphone.track.enabled = enabled;\n    }\n    close() {\n        this.pcDeferred.promise.then(pc => {\n            for (const t of pc.getTransceivers() || []) {\n                try {\n                    t.sender?.track?.stop?.();\n                }\n                catch (e) {\n                }\n            }\n            pc.close();\n        })\n            .catch(() => { });\n        this.pcDeferred.reject(new Error('iceConnectionState ' + this.pc?.iceConnectionState));\n    }\n    async createPeerConnection(setup) {\n        if (this.pc)\n            return;\n        const checkConn = () => {\n            console.log('iceConnectionState', pc.iceConnectionState);\n            console.log('connectionState', pc.connectionState);\n            if (isPeerConnectionClosed(pc))\n                this.close();\n        };\n        const pc = this.pc = new RTCPeerConnection(setup.configuration);\n        this.pcDeferred.resolve(pc);\n        await this.onPeerConnection?.(pc);\n        // pc.addEventListener('connectionstatechange', checkConn);\n        pc.addEventListener('iceconnectionstatechange', checkConn);\n        // pc.addEventListener('icegatheringstatechange', ev => console.log('iceGatheringState', pc.iceGatheringState))\n        // pc.addEventListener('signalingstatechange', ev => console.log('signalingState', pc.signalingState))\n        // pc.addEventListener('icecandidateerror', ev => console.log('icecandidateerror'))\n        if (setup.datachannel) {\n            const dc = pc.createDataChannel(setup.datachannel.label, setup.datachannel.dict);\n            dc.binaryType = 'arraybuffer';\n            this.dcDeferred.resolve(dc);\n        }\n        if (setup.audio) {\n            const audio = pc.addTransceiver('audio', setup.audio);\n            if (setup.audio.direction === 'sendrecv' || setup.audio.direction === 'sendonly') {\n                this.microphone = audio.sender;\n            }\n        }\n        if (setup.video) {\n            if (setup.video.direction === 'sendrecv' || setup.video.direction === 'sendonly') {\n                try {\n                    // doing sendrecv on safari requires a mic be attached, or it fails to connect.\n                    const camera = await navigator.mediaDevices.getUserMedia({ video: true });\n                    for (const track of camera.getTracks()) {\n                        pc.addTrack(track);\n                    }\n                }\n                catch (e) {\n                    // what now\n                }\n            }\n            else {\n                pc.addTransceiver('video', setup.video);\n            }\n        }\n    }\n    async createLocalDescription(type, setup, sendIceCandidate) {\n        await this.createPeerConnection(setup);\n        const gatheringPromise = new Promise(resolve => {\n            this.pc.onicecandidate = ev => {\n                if (ev.candidate) {\n                    // console.log(\"local candidate\", ev.candidate);\n                    sendIceCandidate?.(JSON.parse(JSON.stringify(ev.candidate)));\n                }\n                else {\n                    resolve(undefined);\n                }\n            };\n            this.pc.onicegatheringstatechange = () => {\n                if (this.pc.iceGatheringState === 'complete')\n                    resolve(undefined);\n            };\n        });\n        const toDescription = (init) => {\n            // console.log('local description', init.sdp);\n            return {\n                type: init.type,\n                sdp: init.sdp,\n            };\n        };\n        if (type === 'offer') {\n            let offer = await this.pc.createOffer({\n                offerToReceiveAudio: !!setup.audio,\n                offerToReceiveVideo: !!setup.video,\n            });\n            const set = this.pc.setLocalDescription(offer);\n            if (sendIceCandidate)\n                return toDescription(offer);\n            await set;\n            await gatheringPromise;\n            offer = await this.pc.createOffer({\n                offerToReceiveAudio: !!setup.audio,\n                offerToReceiveVideo: !!setup.video,\n            });\n            return toDescription(offer);\n        }\n        else {\n            let answer = await this.pc.createAnswer();\n            const set = this.pc.setLocalDescription(answer);\n            if (sendIceCandidate)\n                return toDescription(answer);\n            await set;\n            await gatheringPromise;\n            answer = this.pc.currentLocalDescription || answer;\n            return toDescription(answer);\n        }\n    }\n    async setRemoteDescription(description, setup) {\n        await this.createPeerConnection(setup);\n        await this.pc.setRemoteDescription(description);\n        // console.log('remote description', description.sdp);\n    }\n    async addIceCandidate(candidate) {\n        await this.pc.addIceCandidate(candidate);\n        // console.log(\"remote candidate\", candidate);\n    }\n    async endSession() {\n    }\n}\nfunction logSendCandidate(console, type, session) {\n    return async (candidate) => {\n        try {\n            // console.log(`${type} trickled candidate:`, candidate.sdpMLineIndex, candidate.candidate);\n            await session.addIceCandidate(candidate);\n        }\n        catch (e) {\n            console.error('addIceCandidate error', e);\n            throw e;\n        }\n    };\n}\nfunction createCandidateQueue(console, type, session) {\n    let ready = false;\n    let candidateQueue = [];\n    const ls = logSendCandidate(console, type, session);\n    const queueSendCandidate = async (candidate) => {\n        if (!ready)\n            candidateQueue.push(candidate);\n        else\n            ls(candidate);\n    };\n    return {\n        flush() {\n            ready = true;\n            for (const candidate of candidateQueue) {\n                ls(candidate);\n            }\n            candidateQueue = [];\n        },\n        queueSendCandidate,\n    };\n}\nexport async function connectRTCSignalingClients(console, offerClient, offerSetup, answerClient, answerSetup) {\n    const offerOptions = await offerClient.getOptions();\n    const answerOptions = await answerClient.getOptions();\n    const disableTrickle = offerOptions?.disableTrickle || answerOptions?.disableTrickle;\n    if (offerOptions?.offer && answerOptions?.offer)\n        throw new Error('Both RTC clients have offers and can not negotiate. Consider implementing this in @scrypted/webrtc.');\n    if (offerOptions?.requiresOffer && answerOptions.requiresOffer)\n        throw new Error('Both RTC clients require offers and can not negotiate.');\n    offerSetup.type = 'offer';\n    answerSetup.type = 'answer';\n    const answerQueue = createCandidateQueue(console, 'offer', answerClient);\n    const offerQueue = createCandidateQueue(console, 'answer', offerClient);\n    const offer = await offerClient.createLocalDescription('offer', offerSetup, disableTrickle ? undefined : answerQueue.queueSendCandidate);\n    console.log('offer sdp', offer.sdp);\n    await answerClient.setRemoteDescription(offer, answerSetup);\n    answerQueue.flush();\n    const answer = await answerClient.createLocalDescription('answer', answerSetup, disableTrickle ? undefined : offerQueue.queueSendCandidate);\n    console.log('answer sdp', answer.sdp);\n    await offerClient.setRemoteDescription(answer, offerSetup);\n    offerQueue.flush();\n}\n//# sourceMappingURL=rtc-signaling.js.map","import { RpcPeer } from '../../../../../server/src/rpc';\nimport { BrowserSignalingSession, waitPeerConnectionIceConnected, waitPeerIceConnectionClosed } from '../../../../../common/src/rtc-signaling';\ndocument.addEventListener(\"DOMContentLoaded\", function (event) {\n    const options = new cast.framework.CastReceiverOptions();\n    options.disableIdleTimeout = true;\n    cast.framework.CastReceiverContext.getInstance().start(options);\n    const context = cast.framework.CastReceiverContext.getInstance();\n    const playerManager = context.getPlayerManager();\n    const video = document.getElementById('media');\n    let previousCleanup;\n    // intercept the LOAD request to be able to read in a contentId and get data\n    const interceptor = (loadRequestData) => {\n        console.log(loadRequestData);\n        const eioUrl = loadRequestData.media.entity || loadRequestData.media.contentId;\n        const token = loadRequestData.credentials ?? loadRequestData.media.customData.token;\n        const url = new URL(eioUrl);\n        const endpointPath = url.pathname;\n        const query = {};\n        for (const [k, v] of new URLSearchParams(url.search)) {\n            query[k] = v;\n        }\n        const options = {\n            path: endpointPath,\n            query,\n        };\n        const socket = eio(`wss://${url.host}`, options);\n        socket.on('open', async () => {\n            socket.send(JSON.stringify({\n                token,\n            }));\n            const rpcPeer = new RpcPeer('cast-receiver', 'host', (message, reject) => {\n                try {\n                    socket.send(JSON.stringify(message));\n                }\n                catch (e) {\n                    reject?.(e);\n                }\n            });\n            socket.on('message', (data) => {\n                rpcPeer.handleMessage(JSON.parse(data));\n            });\n            const session = new BrowserSignalingSession();\n            const cleanup = () => {\n                console.log('cleanup');\n                socket.close();\n                session.pcDeferred.promise.then(pc => pc.close());\n            };\n            previousCleanup?.();\n            previousCleanup = cleanup;\n            socket.on('close', () => {\n                console.log('socket io connection close event');\n                cleanup();\n            });\n            session.onPeerConnection = async (pc) => {\n                waitPeerIceConnectionClosed(pc).then(cleanup);\n                const mediaStream = new MediaStream(pc.getReceivers().map((receiver) => receiver.track));\n                pc.ontrack = e => mediaStream.addTrack(e.track);\n                video.srcObject = mediaStream;\n                waitPeerConnectionIceConnected(pc)\n                    .then(() => {\n                    socket.removeAllListeners();\n                    // socket.close();\n                });\n            };\n            rpcPeer.params['session'] = session;\n        });\n        return null;\n    };\n    playerManager.setMessageInterceptor(cast.framework.messages.MessageType.LOAD, interceptor);\n});\n//# sourceMappingURL=cast.js.map"],"names":["startPeriodicGarbageCollection","g","gc","setInterval","e","console","warn","RpcProxy","peer","entry","constructorName","proxyProps","proxyOneWayMethods","constructor","this","toPrimitive","selfName","peerName","get","target","p","receiver","RpcPeer","PROPERTY_PROXY_ID","id","PROPERTY_PROXY_PROPERTIES","PROPERTY_PROXY_ONEWAY_METHODS","PROPERTY_JSON_DISABLE_SERIALIZATION","PROPERTY_JSON_COPY_SERIALIZE_CHILDREN","undefined","handleFunctionInvocations","Proxy","set","value","finalizerIdSymbol","finalizerId","apply","thisArg","argArray","Object","isFrozen","pendingResults","Promise","reject","RPCResultError","method","args","serializationContext","arg","push","serialize","rpcApply","type","proxyId","includes","oneway","send","resolve","createPendingResult","Error","cause","message","options","super","name","stack","compileFunction","code","params","f","join","eval","fr","FinalizationRegistry","window","WeakRef","deref","register","idCounter","proxyCounter","localProxied","Map","localProxyMap","remoteWeakProxies","finalizers","finalize","nameDeserializerMap","constructorSerializerMap","transportSafeArgumentTypes","getDefaultTransportSafeArgumentTypes","killed","killedDeferred","static","Symbol","jsonSerializable","Set","add","Number","String","Boolean","Array","thiz","cb","promise","toString","catch","kill","error","result","values","freeze","clear","addSerializer","ctr","serializer","rpcFinalize","__local_proxy_id","__local_proxy_finalizer_id","async","param","paramMessage","evalLocal","script","filename","coercedParams","assign","compile","module","keys","createErrorResult","deserialize","deserializationContext","ret","key","val","entries","__remote_proxy_id","__remote_proxy_finalizer_id","__remote_constructor_name","__serialized_value","__remote_proxy_props","__remote_proxy_oneway_methods","proxy","newProxy","deserializer","has","__proxy_constructor","proxiedEntry","__proxy_id","__proxy_peer","serializerMapName","serialized","proxyConstructorName","localProxiedEntry","rpc","weakref","rpcParam","rpcResult","deferred","local","delete","getEvalSource","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","loaded","__webpack_modules__","d","definition","o","defineProperty","enumerable","globalThis","Function","hmd","create","children","obj","prop","prototype","hasOwnProperty","call","Deferred","finished","v","getUserAgent","navigator","userAgent","waitPeerIceConnectionClosed","pc","addEventListener","isPeerConnectionClosed","iceConnectionState","BrowserSignalingSession","pcDeferred","dcDeferred","microphone","micEnabled","onPeerConnection","capabilities","audio","RTCRtpReceiver","getCapabilities","codecs","headerExtensions","video","screen","width","height","enabled","mic","mediaDevices","getUserMedia","replaceTrack","getTracks","track","close","then","t","getTransceivers","sender","stop","setup","RTCPeerConnection","configuration","log","connectionState","datachannel","dc","createDataChannel","label","dict","binaryType","addTransceiver","direction","camera","addTrack","sendIceCandidate","createPeerConnection","gatheringPromise","onicecandidate","ev","candidate","JSON","parse","stringify","onicegatheringstatechange","iceGatheringState","toDescription","init","sdp","offer","createOffer","offerToReceiveAudio","offerToReceiveVideo","setLocalDescription","answer","createAnswer","currentLocalDescription","description","setRemoteDescription","addIceCandidate","document","event","cast","framework","CastReceiverOptions","disableIdleTimeout","CastReceiverContext","getInstance","start","playerManager","getPlayerManager","getElementById","previousCleanup","setMessageInterceptor","messages","MessageType","LOAD","loadRequestData","eioUrl","media","entity","contentId","token","credentials","customData","url","URL","endpointPath","pathname","query","k","URLSearchParams","search","path","socket","eio","host","on","rpcPeer","data","handleMessage","session","cleanup","mediaStream","MediaStream","getReceivers","map","ontrack","srcObject","reason","waitPeerConnectionIceConnected","removeAllListeners"],"sourceRoot":""} \ No newline at end of file +(()=>{"use strict";var __webpack_modules__={636:(module,__webpack_exports__,__webpack_require__)=>{function startPeriodicGarbageCollection(){let e;__webpack_require__.g.gc||console.warn("rpc peer garbage collection not available: global.gc is not exposed.");try{e=__webpack_require__.g}catch(e){}let t=0;return setInterval((()=>{const r=Date.now(),i=r-t,o=RpcPeer.remotesCreated;RpcPeer.remotesCreated=0;const n=RpcPeer.remotesCollected;RpcPeer.remotesCollected=0,(o||n||i>3e5)&&(t=r,e?.gc?.())}),1e4)}__webpack_require__.d(__webpack_exports__,{uD:()=>RpcPeer}),module=__webpack_require__.hmd(module);class RpcProxy{peer;entry;constructorName;proxyProps;proxyOneWayMethods;constructor(e,t,r,i,o){this.peer=e,this.entry=t,this.constructorName=r,this.proxyProps=i,this.proxyOneWayMethods=o}toPrimitive(){const e=this.peer;return`RpcProxy-${e.selfName}:${e.peerName}: ${this.constructorName}`}get(e,t,r){if(t===RpcPeer.PROPERTY_PROXY_ID)return this.entry.id;if("__proxy_constructor"===t)return this.constructorName;if("__proxy_peer"===t)return this.peer;if(t===RpcPeer.PROPERTY_PROXY_PROPERTIES)return this.proxyProps;if(t===RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS)return this.proxyOneWayMethods;if(t===RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION||t===RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN)return;if("then"===t)return;if("constructor"===t)return;if(void 0!==this.proxyProps?.[t])return this.proxyProps?.[t];return RpcPeer.handleFunctionInvocations(this,e,t,r)||new Proxy((()=>t),this)}set(e,t,r,i){return t===RpcPeer.finalizerIdSymbol?this.entry.finalizerId=r:(this.proxyProps||={},this.proxyProps[t]=r),!0}apply(e,t,r){if(Object.isFrozen(this.peer.pendingResults))return Promise.reject(new RPCResultError(this.peer,"RpcPeer has been killed"));const i=e()||null,o=[],n={};for(const e of r||[])o.push(this.peer.serialize(e,n));const s={type:"apply",id:void 0,proxyId:this.entry.id,args:o,method:i};return this.proxyOneWayMethods?.includes?.(i)?(s.oneway=!0,null===i&&delete s.method,this.peer.send(s,void 0,n),Promise.resolve()):this.peer.createPendingResult(((e,t)=>{s.id=e,this.peer.send(s,t,n)}))}}class RPCResultError extends Error{cause;constructor(e,t,r,i){super(`${e.selfName}:${e.peerName}: ${t}`),this.cause=r,i?.name&&(this.name=i?.name),i?.stack&&(this.stack=`${e.peerName}:${e.selfName}\n${r?.stack||i.stack}`)}}function compileFunction(code,params,options){params=params||[];const f=`(function(${params.join(",")}) {;${code};})`;return eval(f)}try{const e=FinalizationRegistry}catch(e){window.WeakRef=class{target;constructor(e){this.target=e}deref(){return this.target}},window.FinalizationRegistry=class{register(){}}}class RpcPeer{selfName;peerName;send;idCounter=1;params={};pendingResults={};proxyCounter=1;localProxied=new Map;localProxyMap={};remoteWeakProxies={};finalizers=new FinalizationRegistry((e=>this.finalize(e)));nameDeserializerMap=new Map;constructorSerializerMap=new Map;transportSafeArgumentTypes=RpcPeer.getDefaultTransportSafeArgumentTypes();killed;killedDeferred;tags={};static finalizerIdSymbol=Symbol("rpcFinalizerId");static remotesCollected=0;static remotesCreated=0;static activeRpcPeer;static isRpcProxy(e){return!!e?.[RpcPeer.PROPERTY_PROXY_ID]}static getDefaultTransportSafeArgumentTypes(){const e=new Set;return e.add(Number.name),e.add(String.name),e.add(Object.name),e.add(Boolean.name),e.add(Array.name),e}static handleFunctionInvocations(e,t,r,i){return"apply"===r?(r,i)=>e.apply(t,e,i):"call"===r?(r,...i)=>e.apply(t,e,i):"toString"===r||r===Symbol.toPrimitive?(t,...r)=>e.toPrimitive():void 0}static PROPERTY_PROXY_ID="__proxy_id";static PROPERTY_PROXY_ONEWAY_METHODS="__proxy_oneway_methods";static PROPERTY_JSON_DISABLE_SERIALIZATION="__json_disable_serialization";static PROPERTY_PROXY_PROPERTIES="__proxy_props";static PROPERTY_JSON_COPY_SERIALIZE_CHILDREN="__json_copy_serialize_children";static PROBED_PROPERTIES=new Set(["then","constructor","__proxy_id","__proxy_constructor","__proxy_peer",RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS,RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION,RpcPeer.PROPERTY_PROXY_PROPERTIES,RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN]);constructor(e,t,r){this.selfName=e,this.peerName=t,this.send=r,this.killed=new Promise(((e,t)=>{this.killedDeferred={resolve:e,reject:t}})),this.killed.catch((()=>{}))}createPendingResult(e){if(Object.isFrozen(this.pendingResults))return Promise.reject(new RPCResultError(this,"RpcPeer has been killed"));const t=new Promise(((t,r)=>{const i=(this.idCounter++).toString();this.pendingResults[i]={resolve:t,reject:r},e(i,(e=>r(new RPCResultError(this,e.message,e))))}));return t.catch((()=>{})),t}kill(e){const t=new RPCResultError(this,e||"peer was killed");this.killedDeferred.reject(t);for(const e of Object.values(this.pendingResults))e.reject(t);this.pendingResults=Object.freeze({}),this.params=Object.freeze({}),this.remoteWeakProxies=Object.freeze({}),this.localProxyMap=Object.freeze({}),this.localProxied.clear()}addSerializer(e,t,r){this.nameDeserializerMap.set(t,r),this.constructorSerializerMap.set(e,t)}finalize(e){RpcPeer.remotesCollected++,delete this.remoteWeakProxies[e.id];const t={__local_proxy_id:e.id,__local_proxy_finalizer_id:e.finalizerId,type:"finalize"};this.send(t)}async getParam(e){return this.createPendingResult(((t,r)=>{const i={id:t,type:"param",param:e};this.send(i,r)}))}evalLocal(e,t,r){const i=Object.assign({},this.params,r);let o;try{o=module.require("vm").compileFunction}catch(e){o=compileFunction}return o(e,Object.keys(i),{filename:t})(...Object.values(i))}createErrorResult(e,t){e.stack=t.stack||"no stack",e.result=t.name||"no name",e.message=t.message||"no message"}deserialize(e,t){if(!e)return e;if(e[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN]){const r={};for(const[i,o]of Object.entries(e))r[i]=this.deserialize(o,t);return r}const{__remote_proxy_id:r,__remote_proxy_finalizer_id:i,__local_proxy_id:o,__remote_constructor_name:n,__serialized_value:s,__remote_proxy_props:a,__remote_proxy_oneway_methods:c}=e;if(r){let e=this.remoteWeakProxies[r]?.deref();e||(e=this.newProxy(r,n,a,c)),e[RpcPeer.finalizerIdSymbol]=i;const o=this.nameDeserializerMap.get(n);return o?o.deserialize(e,t):e}if(o){const e=this.localProxyMap[o];if(!e)throw new RPCResultError(this,`invalid local proxy id ${o}`);return e}const _=this.nameDeserializerMap.get(n);return _?_.deserialize(s,t):e}serialize(e,t){if(!0===e?.[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN]){const r={};for(const[i,o]of Object.entries(e))r[i]=this.serialize(o,t);return r}if(!e||!e[RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION]&&this.transportSafeArgumentTypes.has(e.constructor?.name))return e;let r=e.__proxy_constructor||e.constructor?.name?.toString(),i=this.localProxied.get(e);if(i){const t=(this.proxyCounter++).toString();return i.finalizerId=t,{__remote_proxy_id:i.id,__remote_proxy_finalizer_id:t,__remote_constructor_name:r,__remote_proxy_props:e?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],__remote_proxy_oneway_methods:e?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS]}}const{__proxy_id:o,__proxy_peer:n}=e;if(o&&n===this)return{__local_proxy_id:o};const s=this.constructorSerializerMap.get(e.constructor);if(s){r=s;const i=this.nameDeserializerMap.get(s);if(!i)throw new Error("serializer not found for "+s);const o=i.serialize(e,t);return{__remote_proxy_id:void 0,__remote_proxy_finalizer_id:void 0,__remote_constructor_name:r,__remote_proxy_props:e?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],__remote_proxy_oneway_methods:e?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],__serialized_value:o}}const a=(this.proxyCounter++).toString();return i={id:a,finalizerId:a},this.localProxied.set(e,i),this.localProxyMap[a]=e,{__remote_proxy_id:a,__remote_proxy_finalizer_id:a,__remote_constructor_name:r,__remote_proxy_props:e?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],__remote_proxy_oneway_methods:e?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS]}}newProxy(e,t,r,i){RpcPeer.remotesCreated++;const o={id:e,finalizerId:void 0},n=new RpcProxy(this,o,t,r,i),s=new Proxy("Function"===t||"AsyncFunction"===t?function(){}:n,n),a=new WeakRef(s);return this.remoteWeakProxies[e]=a,this.finalizers.register(n,o),s}handleMessage(e,t){try{RpcPeer.activeRpcPeer=this,this.handleMessageInternal(e,t)}finally{RpcPeer.activeRpcPeer=void 0}}async handleMessageInternal(e,t){if(!Object.isFrozen(this.pendingResults))try{switch(e.type){case"param":{const t=e,r={},i={type:"result",id:t.id,result:this.serialize(this.params[t.param],r)};this.send(i,void 0,r);break}case"apply":{const r=e,i={type:"result",id:r.id||""},o={};try{const e=this.localProxyMap[r.proxyId];if(!e)throw new Error(`proxy id ${r.proxyId} not found`);const n=[];for(const e of r.args||[])n.push(this.deserialize(e,t));let s;if(r.method){if(!e[r.method])throw new Error(`target ${e?.constructor?.name} does not have method ${r.method}`);s=await e[r.method](...n)}else s=await e(...n);i.result=this.serialize(s,o)}catch(e){this.createErrorResult(i,e)}r.oneway||this.send(i,void 0,o);break}case"result":{const r=e,i=this.pendingResults[r.id];if(delete this.pendingResults[r.id],!i)throw new Error(`unknown result ${r.id}`);if(r.message||r.stack){const e=new RPCResultError(this,r.message||"no message",void 0,{name:r.result,stack:r.stack});return void i.reject(e)}i.resolve(this.deserialize(r.result,t));break}case"finalize":{const t=e,r=this.localProxyMap[t.__local_proxy_id];if(r){const e=this.localProxied.get(r);if(t.__local_proxy_finalizer_id&&t.__local_proxy_finalizer_id!==e?.finalizerId)break;delete this.localProxyMap[t.__local_proxy_id],this.localProxied.delete(r)}break}default:throw new Error(`unknown rpc message type ${e.type}`)}}catch(e){return void console.error("unhandled rpc error",this.peerName,e)}}}function getEvalSource(){return`\n (() => {\n ${RpcProxy}\n\n ${RpcPeer}\n \n return {\n RpcPeer,\n RpcProxy,\n };\n })();\n `}}},__webpack_module_cache__={};function __webpack_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var r=__webpack_module_cache__[e]={id:e,loaded:!1,exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.loaded=!0,r.exports}__webpack_require__.d=(e,t)=>{for(var r in t)__webpack_require__.o(t,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.hmd=e=>((e=Object.create(e)).children||(e.children=[]),Object.defineProperty(e,"exports",{enumerable:!0,set:()=>{throw new Error("ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: "+e.id)}}),e),__webpack_require__.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);var __webpack_exports__={};(()=>{var e=__webpack_require__(636);class t{finished=!1;resolve;reject;promise=new Promise(((e,t)=>{this.resolve=t=>{this.finished=!0,e(t)},this.reject=e=>{this.finished=!0,t(e)}}))}function r(){try{return navigator.userAgent}catch(e){}}function i(e){return new Promise((t=>{e.addEventListener("iceconnectionstatechange",(()=>{o(e)&&t(e.iceConnectionState)}))}))}function o(e){return"disconnected"===e.iceConnectionState||"failed"===e.iceConnectionState||"closed"===e.iceConnectionState}class n{pc;pcDeferred=new t;dcDeferred=new t;microphone;micEnabled=!1;onPeerConnection;options={userAgent:r(),capabilities:{audio:RTCRtpReceiver.getCapabilities?.("audio")||{codecs:void 0,headerExtensions:void 0},video:RTCRtpReceiver.getCapabilities?.("video")||{codecs:void 0,headerExtensions:void 0}},screen:{devicePixelRatio:window.devicePixelRatio,width:screen.width,height:screen.height}};constructor(){}async getOptions(){return this.options}async setMicrophone(e){if(this.microphone&&e&&!this.micEnabled){this.micEnabled=!0;const e=await navigator.mediaDevices.getUserMedia({video:!1,audio:!0});await this.microphone.replaceTrack(e.getTracks()[0])}this.microphone.track.enabled=e}close(){this.pcDeferred.promise.then((e=>{for(const t of e.getTransceivers()||[])try{t.sender?.track?.stop?.()}catch(e){}e.close()})).catch((()=>{})),this.pcDeferred.reject(new Error("iceConnectionState "+this.pc?.iceConnectionState))}async createPeerConnection(e){if(this.pc)return;const t=this.pc=new RTCPeerConnection(e.configuration);if(this.pcDeferred.resolve(t),await(this.onPeerConnection?.(t)),t.addEventListener("iceconnectionstatechange",(()=>{console.log("iceConnectionState",t.iceConnectionState),console.log("connectionState",t.connectionState),o(t)&&this.close()})),e.datachannel){const r=t.createDataChannel(e.datachannel.label,e.datachannel.dict);r.binaryType="arraybuffer",this.dcDeferred.resolve(r)}if(e.audio){let r;r=e.getUserMediaSafariHack&&navigator.userAgent.includes("Safari")&&!navigator.userAgent.includes("Chrome")?t.addTransceiver("audio",{...e.audio,streams:[await navigator.mediaDevices.getUserMedia({audio:!0})]}):t.addTransceiver("audio",e.audio),"sendrecv"!==e.audio.direction&&"sendonly"!==e.audio.direction||(this.microphone=r.sender)}if(e.video)if("sendrecv"===e.video.direction||"sendonly"===e.video.direction)try{const e=await navigator.mediaDevices.getUserMedia({video:!0});for(const r of e.getTracks())t.addTrack(r)}catch(e){}else t.addTransceiver("video",e.video)}async createLocalDescription(e,t,r){await this.createPeerConnection(t);const i=new Promise((e=>{this.pc.onicecandidate=t=>{t.candidate?r?.(JSON.parse(JSON.stringify(t.candidate))):e(void 0)},this.pc.onicegatheringstatechange=()=>{"complete"===this.pc.iceGatheringState&&e(void 0)}})),o=e=>({type:e.type,sdp:e.sdp});if("offer"===e){let e=await this.pc.createOffer({offerToReceiveAudio:!!t.audio,offerToReceiveVideo:!!t.video});const n=this.pc.setLocalDescription(e);return r||(await n,await i,e=await this.pc.createOffer({offerToReceiveAudio:!!t.audio,offerToReceiveVideo:!!t.video})),o(e)}{let e=await this.pc.createAnswer();const t=this.pc.setLocalDescription(e);return r||(await t,await i,e=this.pc.currentLocalDescription||e),o(e)}}async setRemoteDescription(e,t){await this.createPeerConnection(t),await this.pc.setRemoteDescription(e)}async addIceCandidate(e){await this.pc.addIceCandidate(e)}async endSession(){}}document.addEventListener("DOMContentLoaded",(function(t){const r=new cast.framework.CastReceiverOptions;r.disableIdleTimeout=!0,cast.framework.CastReceiverContext.getInstance().start(r);const o=cast.framework.CastReceiverContext.getInstance().getPlayerManager(),s=document.getElementById("media");let a;o.setMessageInterceptor(cast.framework.messages.MessageType.LOAD,(t=>{console.log(t);const r=t.media.entity||t.media.contentId,o=t.credentials??t.media.customData.token,c=new URL(r),_=c.pathname,d={};for(const[e,t]of new URLSearchParams(c.search))d[e]=t;const l={path:_,query:d},p=eio(`wss://${c.host}`,l);return p.on("open",(async()=>{p.send(JSON.stringify({token:o}));const t=new e.uD("cast-receiver","host",((e,t)=>{try{p.send(JSON.stringify(e))}catch(e){t?.(e)}}));p.on("message",(e=>{t.handleMessage(JSON.parse(e))}));const r=new n;r.options.screen.width=1280,r.options.screen.height=720,r.options.screen.devicePixelRatio=1;const c=()=>{console.log("cleanup"),p.close(),r.pcDeferred.promise.then((e=>e.close()))};a?.(),a=c,p.on("close",(()=>{console.log("socket io connection close event"),c()})),r.onPeerConnection=async e=>{i(e).then(c);const t=new MediaStream(e.getReceivers().map((e=>e.track)));e.ontrack=e=>t.addTrack(e.track),s.srcObject=t,function(e){return new Promise(((t,r)=>{"connected"!==e.iceConnectionState?(e.addEventListener("iceconnectionstatechange",(()=>{"connected"===e.iceConnectionState&&t(void 0)})),i(e).then((e=>r(new Error(e))))):t(void 0)}))}(e).then((()=>{p.removeAllListeners()}))},t.params.session=r})),null}))}))})()})(); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","mappings":"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","sources":["webpack:///./dist/server/src/rpc.js","webpack:///webpack/bootstrap","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/global","webpack:///webpack/runtime/harmony module decorator","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///./dist/common/src/deferred.js","webpack:///./dist/common/src/rtc-signaling.js","webpack:///./dist/docs/plugins/google-home/cast-receiver/src/cast.js"],"sourcesContent":["export function startPeriodicGarbageCollection() {\n    if (!global.gc) {\n        console.warn('rpc peer garbage collection not available: global.gc is not exposed.');\n    }\n    let g;\n    try {\n        g = global;\n    }\n    catch (e) {\n    }\n    // periodically see if new objects were created or finalized,\n    // and collect gc if so.\n    let lastCollection = 0;\n    return setInterval(() => {\n        const now = Date.now();\n        const sinceLastCollection = now - lastCollection;\n        const remotesCreated = RpcPeer.remotesCreated;\n        RpcPeer.remotesCreated = 0;\n        const remotesCollected = RpcPeer.remotesCollected;\n        RpcPeer.remotesCollected = 0;\n        if (remotesCreated || remotesCollected || sinceLastCollection > 5 * 60 * 1000) {\n            lastCollection = now;\n            g?.gc?.();\n        }\n    }, 10000);\n}\nclass RpcProxy {\n    peer;\n    entry;\n    constructorName;\n    proxyProps;\n    proxyOneWayMethods;\n    constructor(peer, entry, constructorName, proxyProps, proxyOneWayMethods) {\n        this.peer = peer;\n        this.entry = entry;\n        this.constructorName = constructorName;\n        this.proxyProps = proxyProps;\n        this.proxyOneWayMethods = proxyOneWayMethods;\n    }\n    toPrimitive() {\n        const peer = this.peer;\n        return `RpcProxy-${peer.selfName}:${peer.peerName}: ${this.constructorName}`;\n    }\n    get(target, p, receiver) {\n        if (p === RpcPeer.PROPERTY_PROXY_ID)\n            return this.entry.id;\n        if (p === '__proxy_constructor')\n            return this.constructorName;\n        if (p === '__proxy_peer')\n            return this.peer;\n        if (p === RpcPeer.PROPERTY_PROXY_PROPERTIES)\n            return this.proxyProps;\n        if (p === RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS)\n            return this.proxyOneWayMethods;\n        if (p === RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION || p === RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN)\n            return;\n        if (p === 'then')\n            return;\n        if (p === 'constructor')\n            return;\n        if (this.proxyProps?.[p] !== undefined)\n            return this.proxyProps?.[p];\n        const handled = RpcPeer.handleFunctionInvocations(this, target, p, receiver);\n        if (handled)\n            return handled;\n        return new Proxy(() => p, this);\n    }\n    set(target, p, value, receiver) {\n        if (p === RpcPeer.finalizerIdSymbol) {\n            this.entry.finalizerId = value;\n        }\n        else {\n            this.proxyProps ||= {};\n            this.proxyProps[p] = value;\n        }\n        return true;\n    }\n    apply(target, thisArg, argArray) {\n        if (Object.isFrozen(this.peer.pendingResults))\n            return Promise.reject(new RPCResultError(this.peer, 'RpcPeer has been killed'));\n        // rpc objects can be functions. if the function is a oneway method,\n        // it will have a null in the oneway method list. this is because\n        // undefined is not JSON serializable.\n        const method = target() || null;\n        const args = [];\n        const serializationContext = {};\n        for (const arg of (argArray || [])) {\n            args.push(this.peer.serialize(arg, serializationContext));\n        }\n        const rpcApply = {\n            type: \"apply\",\n            id: undefined,\n            proxyId: this.entry.id,\n            args,\n            method,\n        };\n        if (this.proxyOneWayMethods?.includes?.(method)) {\n            rpcApply.oneway = true;\n            // a oneway callable object doesn't need to be in the JSON payload.\n            if (method === null)\n                delete rpcApply.method;\n            this.peer.send(rpcApply, undefined, serializationContext);\n            return Promise.resolve();\n        }\n        return this.peer.createPendingResult((id, reject) => {\n            rpcApply.id = id;\n            this.peer.send(rpcApply, reject, serializationContext);\n        });\n    }\n}\n// todo: error constructor adds a \"cause\" variable in Chrome 93, Node v??\nexport class RPCResultError extends Error {\n    cause;\n    constructor(peer, message, cause, options) {\n        super(`${peer.selfName}:${peer.peerName}: ${message}`);\n        this.cause = cause;\n        if (options?.name) {\n            this.name = options?.name;\n        }\n        if (options?.stack) {\n            this.stack = `${peer.peerName}:${peer.selfName}\\n${cause?.stack || options.stack}`;\n        }\n    }\n}\nfunction compileFunction(code, params, options) {\n    params = params || [];\n    const f = `(function(${params.join(',')}) {;${code};})`;\n    return eval(f);\n}\ntry {\n    const fr = FinalizationRegistry;\n}\ncatch (e) {\n    window.WeakRef = class WeakRef {\n        target;\n        constructor(target) {\n            this.target = target;\n        }\n        deref() {\n            return this.target;\n        }\n    };\n    window.FinalizationRegistry = class FinalizationRegistry {\n        register() {\n        }\n    };\n}\nexport class RpcPeer {\n    selfName;\n    peerName;\n    send;\n    idCounter = 1;\n    params = {};\n    pendingResults = {};\n    proxyCounter = 1;\n    localProxied = new Map();\n    localProxyMap = {};\n    remoteWeakProxies = {};\n    finalizers = new FinalizationRegistry(entry => this.finalize(entry));\n    nameDeserializerMap = new Map();\n    constructorSerializerMap = new Map();\n    transportSafeArgumentTypes = RpcPeer.getDefaultTransportSafeArgumentTypes();\n    killed;\n    killedDeferred;\n    tags = {};\n    static finalizerIdSymbol = Symbol('rpcFinalizerId');\n    static remotesCollected = 0;\n    static remotesCreated = 0;\n    static activeRpcPeer;\n    static isRpcProxy(value) {\n        return !!value?.[RpcPeer.PROPERTY_PROXY_ID];\n    }\n    static getDefaultTransportSafeArgumentTypes() {\n        const jsonSerializable = new Set();\n        jsonSerializable.add(Number.name);\n        jsonSerializable.add(String.name);\n        jsonSerializable.add(Object.name);\n        jsonSerializable.add(Boolean.name);\n        jsonSerializable.add(Array.name);\n        return jsonSerializable;\n    }\n    static handleFunctionInvocations(thiz, target, p, receiver) {\n        if (p === 'apply') {\n            return (thisArg, args) => {\n                return thiz.apply(target, thiz, args);\n            };\n        }\n        else if (p === 'call') {\n            return (thisArg, ...args) => {\n                return thiz.apply(target, thiz, args);\n            };\n        }\n        else if (p === 'toString' || p === Symbol.toPrimitive) {\n            return (thisArg, ...args) => {\n                return thiz.toPrimitive();\n            };\n        }\n    }\n    static PROPERTY_PROXY_ID = '__proxy_id';\n    static PROPERTY_PROXY_ONEWAY_METHODS = '__proxy_oneway_methods';\n    static PROPERTY_JSON_DISABLE_SERIALIZATION = '__json_disable_serialization';\n    static PROPERTY_PROXY_PROPERTIES = '__proxy_props';\n    static PROPERTY_JSON_COPY_SERIALIZE_CHILDREN = '__json_copy_serialize_children';\n    static PROBED_PROPERTIES = new Set([\n        'then',\n        'constructor',\n        '__proxy_id',\n        '__proxy_constructor',\n        '__proxy_peer',\n        RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS,\n        RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION,\n        RpcPeer.PROPERTY_PROXY_PROPERTIES,\n        RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN,\n    ]);\n    constructor(selfName, peerName, send) {\n        this.selfName = selfName;\n        this.peerName = peerName;\n        this.send = send;\n        this.killed = new Promise((resolve, reject) => {\n            this.killedDeferred = { resolve, reject };\n        });\n        this.killed.catch(() => { });\n    }\n    createPendingResult(cb) {\n        if (Object.isFrozen(this.pendingResults))\n            return Promise.reject(new RPCResultError(this, 'RpcPeer has been killed'));\n        const promise = new Promise((resolve, reject) => {\n            const id = (this.idCounter++).toString();\n            this.pendingResults[id] = { resolve, reject };\n            cb(id, e => reject(new RPCResultError(this, e.message, e)));\n        });\n        // todo: make this an option so rpc doesn't nuke the process if uncaught?\n        promise.catch(() => { });\n        return promise;\n    }\n    kill(message) {\n        const error = new RPCResultError(this, message || 'peer was killed');\n        this.killedDeferred.reject(error);\n        for (const result of Object.values(this.pendingResults)) {\n            result.reject(error);\n        }\n        this.pendingResults = Object.freeze({});\n        this.params = Object.freeze({});\n        this.remoteWeakProxies = Object.freeze({});\n        this.localProxyMap = Object.freeze({});\n        this.localProxied.clear();\n    }\n    // need a name/constructor map due to babel name mangling? fix somehow?\n    addSerializer(ctr, name, serializer) {\n        this.nameDeserializerMap.set(name, serializer);\n        this.constructorSerializerMap.set(ctr, name);\n    }\n    finalize(entry) {\n        RpcPeer.remotesCollected++;\n        delete this.remoteWeakProxies[entry.id];\n        const rpcFinalize = {\n            __local_proxy_id: entry.id,\n            __local_proxy_finalizer_id: entry.finalizerId,\n            type: 'finalize',\n        };\n        this.send(rpcFinalize);\n    }\n    async getParam(param) {\n        return this.createPendingResult((id, reject) => {\n            const paramMessage = {\n                id,\n                type: 'param',\n                param,\n            };\n            this.send(paramMessage, reject);\n        });\n    }\n    evalLocal(script, filename, coercedParams) {\n        const params = Object.assign({}, this.params, coercedParams);\n        let compile;\n        try {\n            // prevent bundlers from trying to include non-existent vm module.\n            compile = module[`require`]('vm').compileFunction;\n        }\n        catch (e) {\n            compile = compileFunction;\n        }\n        const f = compile(script, Object.keys(params), {\n            filename,\n        });\n        const value = f(...Object.values(params));\n        return value;\n    }\n    createErrorResult(result, e) {\n        result.stack = e.stack || 'no stack';\n        result.result = e.name || 'no name';\n        result.message = e.message || 'no message';\n    }\n    deserialize(value, deserializationContext) {\n        if (!value)\n            return value;\n        const copySerializeChildren = value[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN];\n        if (copySerializeChildren) {\n            const ret = {};\n            for (const [key, val] of Object.entries(value)) {\n                ret[key] = this.deserialize(val, deserializationContext);\n            }\n            return ret;\n        }\n        const { __remote_proxy_id, __remote_proxy_finalizer_id, __local_proxy_id, __remote_constructor_name, __serialized_value, __remote_proxy_props, __remote_proxy_oneway_methods } = value;\n        if (__remote_proxy_id) {\n            let proxy = this.remoteWeakProxies[__remote_proxy_id]?.deref();\n            if (!proxy)\n                proxy = this.newProxy(__remote_proxy_id, __remote_constructor_name, __remote_proxy_props, __remote_proxy_oneway_methods);\n            proxy[RpcPeer.finalizerIdSymbol] = __remote_proxy_finalizer_id;\n            const deserializer = this.nameDeserializerMap.get(__remote_constructor_name);\n            if (deserializer) {\n                return deserializer.deserialize(proxy, deserializationContext);\n            }\n            return proxy;\n        }\n        if (__local_proxy_id) {\n            const ret = this.localProxyMap[__local_proxy_id];\n            if (!ret)\n                throw new RPCResultError(this, `invalid local proxy id ${__local_proxy_id}`);\n            return ret;\n        }\n        const deserializer = this.nameDeserializerMap.get(__remote_constructor_name);\n        if (deserializer) {\n            return deserializer.deserialize(__serialized_value, deserializationContext);\n        }\n        return value;\n    }\n    serialize(value, serializationContext) {\n        if (value?.[RpcPeer.PROPERTY_JSON_COPY_SERIALIZE_CHILDREN] === true) {\n            const ret = {};\n            for (const [key, val] of Object.entries(value)) {\n                ret[key] = this.serialize(val, serializationContext);\n            }\n            return ret;\n        }\n        if (!value || (!value[RpcPeer.PROPERTY_JSON_DISABLE_SERIALIZATION] && this.transportSafeArgumentTypes.has(value.constructor?.name))) {\n            return value;\n        }\n        let __remote_constructor_name = value.__proxy_constructor || value.constructor?.name?.toString();\n        let proxiedEntry = this.localProxied.get(value);\n        if (proxiedEntry) {\n            const __remote_proxy_finalizer_id = (this.proxyCounter++).toString();\n            proxiedEntry.finalizerId = __remote_proxy_finalizer_id;\n            const ret = {\n                __remote_proxy_id: proxiedEntry.id,\n                __remote_proxy_finalizer_id,\n                __remote_constructor_name,\n                __remote_proxy_props: value?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],\n                __remote_proxy_oneway_methods: value?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],\n            };\n            return ret;\n        }\n        const { __proxy_id, __proxy_peer } = value;\n        if (__proxy_id && __proxy_peer === this) {\n            const ret = {\n                __local_proxy_id: __proxy_id,\n            };\n            return ret;\n        }\n        const serializerMapName = this.constructorSerializerMap.get(value.constructor);\n        if (serializerMapName) {\n            __remote_constructor_name = serializerMapName;\n            const serializer = this.nameDeserializerMap.get(serializerMapName);\n            if (!serializer)\n                throw new Error('serializer not found for ' + serializerMapName);\n            const serialized = serializer.serialize(value, serializationContext);\n            const ret = {\n                __remote_proxy_id: undefined,\n                __remote_proxy_finalizer_id: undefined,\n                __remote_constructor_name,\n                __remote_proxy_props: value?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],\n                __remote_proxy_oneway_methods: value?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],\n                __serialized_value: serialized,\n            };\n            return ret;\n        }\n        const __remote_proxy_id = (this.proxyCounter++).toString();\n        proxiedEntry = {\n            id: __remote_proxy_id,\n            finalizerId: __remote_proxy_id,\n        };\n        this.localProxied.set(value, proxiedEntry);\n        this.localProxyMap[__remote_proxy_id] = value;\n        const ret = {\n            __remote_proxy_id,\n            __remote_proxy_finalizer_id: __remote_proxy_id,\n            __remote_constructor_name,\n            __remote_proxy_props: value?.[RpcPeer.PROPERTY_PROXY_PROPERTIES],\n            __remote_proxy_oneway_methods: value?.[RpcPeer.PROPERTY_PROXY_ONEWAY_METHODS],\n        };\n        return ret;\n    }\n    newProxy(proxyId, proxyConstructorName, proxyProps, proxyOneWayMethods) {\n        RpcPeer.remotesCreated++;\n        const localProxiedEntry = {\n            id: proxyId,\n            finalizerId: undefined,\n        };\n        const rpc = new RpcProxy(this, localProxiedEntry, proxyConstructorName, proxyProps, proxyOneWayMethods);\n        const target = proxyConstructorName === 'Function' || proxyConstructorName === 'AsyncFunction' ? function () { } : rpc;\n        const proxy = new Proxy(target, rpc);\n        const weakref = new WeakRef(proxy);\n        this.remoteWeakProxies[proxyId] = weakref;\n        this.finalizers.register(rpc, localProxiedEntry);\n        return proxy;\n    }\n    handleMessage(message, deserializationContext) {\n        try {\n            RpcPeer.activeRpcPeer = this;\n            this.handleMessageInternal(message, deserializationContext);\n        }\n        finally {\n            RpcPeer.activeRpcPeer = undefined;\n        }\n    }\n    async handleMessageInternal(message, deserializationContext) {\n        if (Object.isFrozen(this.pendingResults))\n            return;\n        try {\n            switch (message.type) {\n                case 'param': {\n                    const rpcParam = message;\n                    const serializationContext = {};\n                    const result = {\n                        type: 'result',\n                        id: rpcParam.id,\n                        result: this.serialize(this.params[rpcParam.param], serializationContext)\n                    };\n                    this.send(result, undefined, serializationContext);\n                    break;\n                }\n                case 'apply': {\n                    const rpcApply = message;\n                    const result = {\n                        type: 'result',\n                        id: rpcApply.id || '',\n                    };\n                    const serializationContext = {};\n                    try {\n                        const target = this.localProxyMap[rpcApply.proxyId];\n                        if (!target)\n                            throw new Error(`proxy id ${rpcApply.proxyId} not found`);\n                        const args = [];\n                        for (const arg of (rpcApply.args || [])) {\n                            args.push(this.deserialize(arg, deserializationContext));\n                        }\n                        let value;\n                        if (rpcApply.method) {\n                            const method = target[rpcApply.method];\n                            if (!method)\n                                throw new Error(`target ${target?.constructor?.name} does not have method ${rpcApply.method}`);\n                            value = await target[rpcApply.method](...args);\n                        }\n                        else {\n                            value = await target(...args);\n                        }\n                        result.result = this.serialize(value, serializationContext);\n                    }\n                    catch (e) {\n                        // console.error('failure', rpcApply.method, e);\n                        this.createErrorResult(result, e);\n                    }\n                    if (!rpcApply.oneway)\n                        this.send(result, undefined, serializationContext);\n                    break;\n                }\n                case 'result': {\n                    const rpcResult = message;\n                    const deferred = this.pendingResults[rpcResult.id];\n                    delete this.pendingResults[rpcResult.id];\n                    if (!deferred)\n                        throw new Error(`unknown result ${rpcResult.id}`);\n                    if (rpcResult.message || rpcResult.stack) {\n                        const e = new RPCResultError(this, rpcResult.message || 'no message', undefined, {\n                            name: rpcResult.result,\n                            stack: rpcResult.stack,\n                        });\n                        deferred.reject(e);\n                        return;\n                    }\n                    deferred.resolve(this.deserialize(rpcResult.result, deserializationContext));\n                    break;\n                }\n                case 'finalize': {\n                    const rpcFinalize = message;\n                    const local = this.localProxyMap[rpcFinalize.__local_proxy_id];\n                    if (local) {\n                        const localProxiedEntry = this.localProxied.get(local);\n                        // if a finalizer id is specified, it must match.\n                        if (rpcFinalize.__local_proxy_finalizer_id && rpcFinalize.__local_proxy_finalizer_id !== localProxiedEntry?.finalizerId) {\n                            break;\n                        }\n                        delete this.localProxyMap[rpcFinalize.__local_proxy_id];\n                        this.localProxied.delete(local);\n                    }\n                    break;\n                }\n                default:\n                    throw new Error(`unknown rpc message type ${message.type}`);\n            }\n        }\n        catch (e) {\n            console.error('unhandled rpc error', this.peerName, e);\n            return;\n        }\n    }\n}\nexport function getEvalSource() {\n    return `\n    (() => {\n        ${RpcProxy}\n\n        ${RpcPeer}\n    \n        return {\n            RpcPeer,\n            RpcProxy,\n        };\n    })();\n    `;\n}\n//# sourceMappingURL=rpc.js.map","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.hmd = (module) => {\n\tmodule = Object.create(module);\n\tif (!module.children) module.children = [];\n\tObject.defineProperty(module, 'exports', {\n\t\tenumerable: true,\n\t\tset: () => {\n\t\t\tthrow new Error('ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: ' + module.id);\n\t\t}\n\t});\n\treturn module;\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","export class Deferred {\n    finished = false;\n    resolve;\n    reject;\n    promise = new Promise((resolve, reject) => {\n        this.resolve = v => {\n            this.finished = true;\n            resolve(v);\n        };\n        this.reject = e => {\n            this.finished = true;\n            reject(e);\n        };\n    });\n}\n//# sourceMappingURL=deferred.js.map","import { Deferred } from \"./deferred\";\nfunction getUserAgent() {\n    try {\n        return navigator.userAgent;\n    }\n    catch (e) {\n    }\n}\n// connectionState is not implemented in firefox? so watch iceConnectionState instead...\nexport function waitPeerConnectionIceConnected(pc) {\n    return new Promise((resolve, reject) => {\n        if (pc.iceConnectionState === 'connected') {\n            resolve(undefined);\n            return;\n        }\n        pc.addEventListener('iceconnectionstatechange', () => {\n            if (pc.iceConnectionState === 'connected')\n                resolve(undefined);\n        });\n        waitPeerIceConnectionClosed(pc).then(reason => reject(new Error(reason)));\n    });\n}\nexport function waitPeerIceConnectionClosed(pc) {\n    return new Promise(resolve => {\n        pc.addEventListener('iceconnectionstatechange', () => {\n            if (isPeerConnectionClosed(pc)) {\n                resolve(pc.iceConnectionState);\n            }\n        });\n    });\n}\nexport function isPeerConnectionClosed(pc) {\n    return pc.iceConnectionState === 'disconnected'\n        || pc.iceConnectionState === 'failed'\n        || pc.iceConnectionState === 'closed';\n}\nfunction silence() {\n    let ctx = new AudioContext(), oscillator = ctx.createOscillator();\n    const dest = ctx.createMediaStreamDestination();\n    oscillator.connect(dest);\n    oscillator.start();\n    const ret = dest.stream.getAudioTracks()[0];\n    ret.enabled = false;\n    return ret;\n}\nexport class BrowserSignalingSession {\n    pc;\n    pcDeferred = new Deferred();\n    dcDeferred = new Deferred();\n    microphone;\n    micEnabled = false;\n    onPeerConnection;\n    options = {\n        userAgent: getUserAgent(),\n        capabilities: {\n            audio: RTCRtpReceiver.getCapabilities?.('audio') || {\n                codecs: undefined,\n                headerExtensions: undefined,\n            },\n            video: RTCRtpReceiver.getCapabilities?.('video') || {\n                codecs: undefined,\n                headerExtensions: undefined,\n            },\n        },\n        screen: {\n            devicePixelRatio: window.devicePixelRatio,\n            width: screen.width,\n            height: screen.height,\n        },\n    };\n    constructor() {\n    }\n    async getOptions() {\n        return this.options;\n    }\n    async setMicrophone(enabled) {\n        if (this.microphone && enabled && !this.micEnabled) {\n            this.micEnabled = true;\n            // doing sendrecv on safari requires a mic be attached, or it fails to connect.\n            const mic = await navigator.mediaDevices.getUserMedia({ video: false, audio: true });\n            await this.microphone.replaceTrack(mic.getTracks()[0]);\n        }\n        this.microphone.track.enabled = enabled;\n    }\n    close() {\n        this.pcDeferred.promise.then(pc => {\n            for (const t of pc.getTransceivers() || []) {\n                try {\n                    t.sender?.track?.stop?.();\n                }\n                catch (e) {\n                }\n            }\n            pc.close();\n        })\n            .catch(() => { });\n        this.pcDeferred.reject(new Error('iceConnectionState ' + this.pc?.iceConnectionState));\n    }\n    async createPeerConnection(setup) {\n        if (this.pc)\n            return;\n        const checkConn = () => {\n            console.log('iceConnectionState', pc.iceConnectionState);\n            console.log('connectionState', pc.connectionState);\n            if (isPeerConnectionClosed(pc))\n                this.close();\n        };\n        const pc = this.pc = new RTCPeerConnection(setup.configuration);\n        this.pcDeferred.resolve(pc);\n        await this.onPeerConnection?.(pc);\n        // pc.addEventListener('connectionstatechange', checkConn);\n        pc.addEventListener('iceconnectionstatechange', checkConn);\n        // pc.addEventListener('icegatheringstatechange', ev => console.log('iceGatheringState', pc.iceGatheringState))\n        // pc.addEventListener('signalingstatechange', ev => console.log('signalingState', pc.signalingState))\n        // pc.addEventListener('icecandidateerror', ev => console.log('icecandidateerror'))\n        if (setup.datachannel) {\n            const dc = pc.createDataChannel(setup.datachannel.label, setup.datachannel.dict);\n            dc.binaryType = 'arraybuffer';\n            this.dcDeferred.resolve(dc);\n        }\n        if (setup.audio) {\n            let audio;\n            if (setup.getUserMediaSafariHack && navigator.userAgent.includes('Safari') && !navigator.userAgent.includes('Chrome')) {\n                // offering a sendrecv on safari requires a mic be attached for ring webrtc, or it fails to stream?\n                // even if a silent track is used...\n                audio = pc.addTransceiver('audio', {\n                    ...setup.audio,\n                    streams: [\n                        await navigator.mediaDevices.getUserMedia({ audio: true })\n                    ],\n                });\n            }\n            else {\n                audio = pc.addTransceiver('audio', setup.audio);\n            }\n            if (setup.audio.direction === 'sendrecv' || setup.audio.direction === 'sendonly') {\n                this.microphone = audio.sender;\n            }\n        }\n        if (setup.video) {\n            if (setup.video.direction === 'sendrecv' || setup.video.direction === 'sendonly') {\n                try {\n                    const camera = await navigator.mediaDevices.getUserMedia({ video: true });\n                    for (const track of camera.getTracks()) {\n                        pc.addTrack(track);\n                    }\n                }\n                catch (e) {\n                    // what now\n                }\n            }\n            else {\n                pc.addTransceiver('video', setup.video);\n            }\n        }\n    }\n    async createLocalDescription(type, setup, sendIceCandidate) {\n        await this.createPeerConnection(setup);\n        const gatheringPromise = new Promise(resolve => {\n            this.pc.onicecandidate = ev => {\n                if (ev.candidate) {\n                    // console.log(\"local candidate\", ev.candidate);\n                    sendIceCandidate?.(JSON.parse(JSON.stringify(ev.candidate)));\n                }\n                else {\n                    resolve(undefined);\n                }\n            };\n            this.pc.onicegatheringstatechange = () => {\n                if (this.pc.iceGatheringState === 'complete')\n                    resolve(undefined);\n            };\n        });\n        const toDescription = (init) => {\n            // console.log('local description', init.sdp);\n            return {\n                type: init.type,\n                sdp: init.sdp,\n            };\n        };\n        if (type === 'offer') {\n            let offer = await this.pc.createOffer({\n                offerToReceiveAudio: !!setup.audio,\n                offerToReceiveVideo: !!setup.video,\n            });\n            const set = this.pc.setLocalDescription(offer);\n            if (sendIceCandidate)\n                return toDescription(offer);\n            await set;\n            await gatheringPromise;\n            offer = await this.pc.createOffer({\n                offerToReceiveAudio: !!setup.audio,\n                offerToReceiveVideo: !!setup.video,\n            });\n            return toDescription(offer);\n        }\n        else {\n            let answer = await this.pc.createAnswer();\n            const set = this.pc.setLocalDescription(answer);\n            if (sendIceCandidate)\n                return toDescription(answer);\n            await set;\n            await gatheringPromise;\n            answer = this.pc.currentLocalDescription || answer;\n            return toDescription(answer);\n        }\n    }\n    async setRemoteDescription(description, setup) {\n        await this.createPeerConnection(setup);\n        await this.pc.setRemoteDescription(description);\n        // console.log('remote description', description.sdp);\n    }\n    async addIceCandidate(candidate) {\n        await this.pc.addIceCandidate(candidate);\n        // console.log(\"remote candidate\", candidate);\n    }\n    async endSession() {\n    }\n}\nfunction logSendCandidate(console, type, session) {\n    return async (candidate) => {\n        try {\n            console.log(`${type} trickled candidate:`, candidate.sdpMLineIndex, candidate.candidate);\n            await session.addIceCandidate(candidate);\n        }\n        catch (e) {\n            console.error('addIceCandidate error', e);\n            throw e;\n        }\n    };\n}\nfunction createCandidateQueue(console, type, session) {\n    let ready = false;\n    let candidateQueue = [];\n    const ls = logSendCandidate(console, type, session);\n    const queueSendCandidate = async (candidate) => {\n        if (!ready)\n            candidateQueue.push(candidate);\n        else\n            ls(candidate);\n    };\n    return {\n        flush() {\n            ready = true;\n            for (const candidate of candidateQueue) {\n                ls(candidate);\n            }\n            candidateQueue = [];\n        },\n        queueSendCandidate,\n    };\n}\nexport async function connectRTCSignalingClients(console, offerClient, offerSetup, answerClient, answerSetup) {\n    const offerOptions = await offerClient.getOptions();\n    const answerOptions = await answerClient.getOptions();\n    const disableTrickle = offerOptions?.disableTrickle || answerOptions?.disableTrickle;\n    if (offerOptions?.offer && answerOptions?.offer)\n        throw new Error('Both RTC clients have offers and can not negotiate. Consider implementing this in @scrypted/webrtc.');\n    if (offerOptions?.requiresOffer && answerOptions.requiresOffer)\n        throw new Error('Both RTC clients require offers and can not negotiate.');\n    offerSetup.type = 'offer';\n    answerSetup.type = 'answer';\n    const answerQueue = createCandidateQueue(console, 'offer', answerClient);\n    const offerQueue = createCandidateQueue(console, 'answer', offerClient);\n    const offer = await offerClient.createLocalDescription('offer', offerSetup, disableTrickle ? undefined : answerQueue.queueSendCandidate);\n    console.log('offer sdp', offer.sdp);\n    await answerClient.setRemoteDescription(offer, answerSetup);\n    const answer = await answerClient.createLocalDescription('answer', answerSetup, disableTrickle ? undefined : offerQueue.queueSendCandidate);\n    console.log('answer sdp', answer.sdp);\n    await offerClient.setRemoteDescription(answer, offerSetup);\n    offerQueue.flush();\n    answerQueue.flush();\n}\n//# sourceMappingURL=rtc-signaling.js.map","import { RpcPeer } from '../../../../../server/src/rpc';\nimport { BrowserSignalingSession, waitPeerConnectionIceConnected, waitPeerIceConnectionClosed } from '../../../../../common/src/rtc-signaling';\ndocument.addEventListener(\"DOMContentLoaded\", function (event) {\n    const options = new cast.framework.CastReceiverOptions();\n    options.disableIdleTimeout = true;\n    cast.framework.CastReceiverContext.getInstance().start(options);\n    const context = cast.framework.CastReceiverContext.getInstance();\n    const playerManager = context.getPlayerManager();\n    const video = document.getElementById('media');\n    let previousCleanup;\n    // intercept the LOAD request to be able to read in a contentId and get data\n    const interceptor = (loadRequestData) => {\n        console.log(loadRequestData);\n        const eioUrl = loadRequestData.media.entity || loadRequestData.media.contentId;\n        const token = loadRequestData.credentials ?? loadRequestData.media.customData.token;\n        const url = new URL(eioUrl);\n        const endpointPath = url.pathname;\n        const query = {};\n        for (const [k, v] of new URLSearchParams(url.search)) {\n            query[k] = v;\n        }\n        const options = {\n            path: endpointPath,\n            query,\n        };\n        const socket = eio(`wss://${url.host}`, options);\n        socket.on('open', async () => {\n            socket.send(JSON.stringify({\n                token,\n            }));\n            const rpcPeer = new RpcPeer('cast-receiver', 'host', (message, reject) => {\n                try {\n                    socket.send(JSON.stringify(message));\n                }\n                catch (e) {\n                    reject?.(e);\n                }\n            });\n            socket.on('message', (data) => {\n                rpcPeer.handleMessage(JSON.parse(data));\n            });\n            const session = new BrowserSignalingSession();\n            // nest hub devices lie about their capabilties, such as\n            // reporting that they support 4k and h264 high.\n            session.options.screen.width = 1280;\n            session.options.screen.height = 720;\n            session.options.screen.devicePixelRatio = 1;\n            const cleanup = () => {\n                console.log('cleanup');\n                socket.close();\n                session.pcDeferred.promise.then(pc => pc.close());\n            };\n            previousCleanup?.();\n            previousCleanup = cleanup;\n            socket.on('close', () => {\n                console.log('socket io connection close event');\n                cleanup();\n            });\n            session.onPeerConnection = async (pc) => {\n                waitPeerIceConnectionClosed(pc).then(cleanup);\n                const mediaStream = new MediaStream(pc.getReceivers().map((receiver) => receiver.track));\n                pc.ontrack = e => mediaStream.addTrack(e.track);\n                video.srcObject = mediaStream;\n                waitPeerConnectionIceConnected(pc)\n                    .then(() => {\n                    socket.removeAllListeners();\n                    // socket.close();\n                });\n            };\n            rpcPeer.params['session'] = session;\n        });\n        return null;\n    };\n    playerManager.setMessageInterceptor(cast.framework.messages.MessageType.LOAD, interceptor);\n});\n//# sourceMappingURL=cast.js.map"],"names":["startPeriodicGarbageCollection","g","gc","console","warn","e","lastCollection","setInterval","now","Date","sinceLastCollection","remotesCreated","RpcPeer","remotesCollected","RpcProxy","peer","entry","constructorName","proxyProps","proxyOneWayMethods","constructor","this","toPrimitive","selfName","peerName","get","target","p","receiver","PROPERTY_PROXY_ID","id","PROPERTY_PROXY_PROPERTIES","PROPERTY_PROXY_ONEWAY_METHODS","PROPERTY_JSON_DISABLE_SERIALIZATION","PROPERTY_JSON_COPY_SERIALIZE_CHILDREN","undefined","handleFunctionInvocations","Proxy","set","value","finalizerIdSymbol","finalizerId","apply","thisArg","argArray","Object","isFrozen","pendingResults","Promise","reject","RPCResultError","method","args","serializationContext","arg","push","serialize","rpcApply","type","proxyId","includes","oneway","send","resolve","createPendingResult","Error","cause","message","options","super","name","stack","compileFunction","code","params","f","join","eval","fr","FinalizationRegistry","window","WeakRef","deref","register","idCounter","proxyCounter","localProxied","Map","localProxyMap","remoteWeakProxies","finalizers","finalize","nameDeserializerMap","constructorSerializerMap","transportSafeArgumentTypes","getDefaultTransportSafeArgumentTypes","killed","killedDeferred","tags","static","Symbol","jsonSerializable","Set","add","Number","String","Boolean","Array","thiz","catch","cb","promise","toString","kill","error","result","values","freeze","clear","addSerializer","ctr","serializer","rpcFinalize","__local_proxy_id","__local_proxy_finalizer_id","async","param","paramMessage","evalLocal","script","filename","coercedParams","assign","compile","module","keys","createErrorResult","deserialize","deserializationContext","ret","key","val","entries","__remote_proxy_id","__remote_proxy_finalizer_id","__remote_constructor_name","__serialized_value","__remote_proxy_props","__remote_proxy_oneway_methods","proxy","newProxy","deserializer","has","__proxy_constructor","proxiedEntry","__proxy_id","__proxy_peer","serializerMapName","serialized","proxyConstructorName","localProxiedEntry","rpc","weakref","handleMessage","activeRpcPeer","handleMessageInternal","rpcParam","rpcResult","deferred","local","delete","getEvalSource","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","loaded","__webpack_modules__","d","definition","o","defineProperty","enumerable","globalThis","Function","hmd","create","children","obj","prop","prototype","hasOwnProperty","call","Deferred","finished","v","getUserAgent","navigator","userAgent","waitPeerIceConnectionClosed","pc","addEventListener","isPeerConnectionClosed","iceConnectionState","BrowserSignalingSession","pcDeferred","dcDeferred","microphone","micEnabled","onPeerConnection","capabilities","audio","RTCRtpReceiver","getCapabilities","codecs","headerExtensions","video","screen","devicePixelRatio","width","height","enabled","mic","mediaDevices","getUserMedia","replaceTrack","getTracks","track","close","then","t","getTransceivers","sender","stop","setup","RTCPeerConnection","configuration","log","connectionState","datachannel","dc","createDataChannel","label","dict","binaryType","getUserMediaSafariHack","addTransceiver","streams","direction","camera","addTrack","sendIceCandidate","createPeerConnection","gatheringPromise","onicecandidate","ev","candidate","JSON","parse","stringify","onicegatheringstatechange","iceGatheringState","toDescription","init","sdp","offer","createOffer","offerToReceiveAudio","offerToReceiveVideo","setLocalDescription","answer","createAnswer","currentLocalDescription","description","setRemoteDescription","addIceCandidate","document","event","cast","framework","CastReceiverOptions","disableIdleTimeout","CastReceiverContext","getInstance","start","playerManager","getPlayerManager","getElementById","previousCleanup","setMessageInterceptor","messages","MessageType","LOAD","loadRequestData","eioUrl","media","entity","contentId","token","credentials","customData","url","URL","endpointPath","pathname","query","k","URLSearchParams","search","path","socket","eio","host","on","rpcPeer","data","session","cleanup","mediaStream","MediaStream","getReceivers","map","ontrack","srcObject","reason","waitPeerConnectionIceConnected","removeAllListeners"],"sourceRoot":""} \ No newline at end of file diff --git a/docs/plugins/google-home/cast-receiver/src/cast.ts b/docs/plugins/google-home/cast-receiver/src/cast.ts index f613e496e..37fda71f1 100644 --- a/docs/plugins/google-home/cast-receiver/src/cast.ts +++ b/docs/plugins/google-home/cast-receiver/src/cast.ts @@ -53,6 +53,12 @@ document.addEventListener("DOMContentLoaded", function (event) { }); const session = new BrowserSignalingSession(); + // nest hub devices lie about their capabilties, such as + // reporting that they support 4k and h264 high. + // this causes high res streams to fail to load. + session.options.screen.width = 1280; + session.options.screen.height = 720; + session.options.screen.devicePixelRatio = 1; const cleanup = () => { console.log('cleanup'); diff --git a/external/werift b/external/werift index 571c19a84..f1cf69407 160000 --- a/external/werift +++ b/external/werift @@ -1 +1 @@ -Subproject commit 571c19a8473984c5350d430a6eb5be99b6249206 +Subproject commit f1cf694073e02fc4c5ebad966de6d97d1f822a81 diff --git a/plugins/alexa/package-lock.json b/plugins/alexa/package-lock.json index 2311d4370..a43ab55ee 100644 --- a/plugins/alexa/package-lock.json +++ b/plugins/alexa/package-lock.json @@ -1,12 +1,12 @@ { "name": "@scrypted/alexa", - "version": "0.0.19", + "version": "0.0.20", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@scrypted/alexa", - "version": "0.0.19", + "version": "0.0.20", "dependencies": { "@types/node": "^16.6.1", "alexa-smarthome-ts": "^0.0.1", diff --git a/plugins/alexa/package.json b/plugins/alexa/package.json index 1f76b338b..682a01d36 100644 --- a/plugins/alexa/package.json +++ b/plugins/alexa/package.json @@ -1,6 +1,6 @@ { "name": "@scrypted/alexa", - "version": "0.0.19", + "version": "0.0.20", "scripts": { "scrypted-setup-project": "scrypted-setup-project", "prescrypted-setup-project": "scrypted-package-json", diff --git a/plugins/alexa/src/types/camera.ts b/plugins/alexa/src/types/camera.ts index 025aa936f..1f9a71d9e 100644 --- a/plugins/alexa/src/types/camera.ts +++ b/plugins/alexa/src/types/camera.ts @@ -50,7 +50,7 @@ addSupportedType(ScryptedDeviceType.Camera, { capabilities } }, - async reportState(device: ScryptedDevice & MotionSensor): Promise{ + async reportState(device: ScryptedDevice & MotionSensor): Promise { return { type: 'state', namespace: 'Alexa', @@ -110,6 +110,12 @@ export class AlexaSignalingSession implements RTCSignalingSession { sdp: this.directive.payload.offer.value, }, disableTrickle: true, + // this could be a low resolution screen, no way of knowing, so never send a + // 1080p+ stream. + screen: { + width: 1280, + height: 720, + } } } diff --git a/plugins/bticino/src/main.ts b/plugins/bticino/src/main.ts index 5e5e0d582..328570c99 100644 --- a/plugins/bticino/src/main.ts +++ b/plugins/bticino/src/main.ts @@ -326,7 +326,7 @@ export class SipCamProvider extends ScryptedDeviceBase implements DeviceProvider } } - async releaseDevice(id: string, nativeId: string, device: any): Promise { + async releaseDevice(id: string, nativeId: string): Promise { } async createDevice(settings: DeviceCreatorSettings): Promise { diff --git a/plugins/chromecast/README.md b/plugins/chromecast/README.md index c996e9d75..388878ffc 100644 --- a/plugins/chromecast/README.md +++ b/plugins/chromecast/README.md @@ -1,15 +1,5 @@ -# Send video, audio, and text to speech notifications to Chromecast and Google Home devices +# Chromecast Plugin for Scrypted. -## npm commands - * npm run scrypted-webpack - * npm run scrypted-deploy - * npm run scrypted-debug +Send media to Chromecast and Google Home devices. -## scrypted distribution via npm - 1. Ensure package.json is set up properly for publishing on npm. - 2. npm publish - -## Visual Studio Code configuration - -* If using a remote server, edit [.vscode/settings.json](blob/master/.vscode/settings.json) to specify the IP Address of the Scrypted server. -* Launch Scrypted Debugger from the launch menu. +Scrypted Cloud setup is required for live streams. diff --git a/plugins/chromecast/package-lock.json b/plugins/chromecast/package-lock.json index aa0c7ff80..bbe55fcb5 100644 --- a/plugins/chromecast/package-lock.json +++ b/plugins/chromecast/package-lock.json @@ -1,12 +1,12 @@ { "name": "@scrypted/chromecast", - "version": "0.1.53", + "version": "0.1.55", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@scrypted/chromecast", - "version": "0.1.53", + "version": "0.1.55", "hasInstallScript": true, "license": "Apache-2.0", "dependencies": { diff --git a/plugins/chromecast/package.json b/plugins/chromecast/package.json index f5be19b08..c97d6de70 100644 --- a/plugins/chromecast/package.json +++ b/plugins/chromecast/package.json @@ -1,6 +1,6 @@ { "name": "@scrypted/chromecast", - "version": "0.1.53", + "version": "0.1.55", "description": "Send video, audio, and text to speech notifications to Chromecast and Google Home devices", "author": "Scrypted", "license": "Apache-2.0", @@ -30,7 +30,8 @@ "DeviceProvider" ], "pluginDependencies": [ - "@scrypted/webrtc" + "@scrypted/webrtc", + "@scrypted/cloud" ] }, "dependencies": { diff --git a/plugins/chromecast/src/main.ts b/plugins/chromecast/src/main.ts index a23cd0181..60676b8cb 100644 --- a/plugins/chromecast/src/main.ts +++ b/plugins/chromecast/src/main.ts @@ -201,7 +201,15 @@ class CastDevice extends ScryptedDeviceBase implements MediaPlayer, Refresh, Eng const engineio = await endpointManager.getPublicLocalEndpoint(this.nativeId) + 'engine.io/'; const mo = await mediaManager.createMediaObject(Buffer.from(engineio), ScryptedMimeTypes.LocalUrl); - const cameraStreamAuthToken = await mediaManager.convertMediaObjectToUrl(mo, ScryptedMimeTypes.LocalUrl); + let cameraStreamAuthToken: string; + + try { + cameraStreamAuthToken= await mediaManager.convertMediaObjectToUrl(mo, ScryptedMimeTypes.LocalUrl); + } + catch (e) { + this.log.a('Streaming failed. Install and set up Scrypted Cloud to cast this media type.'); + throw e; + } const castMedia: any = { contentId: cameraStreamAuthToken, @@ -550,7 +558,7 @@ class CastDeviceProvider extends ScryptedDeviceBase implements DeviceProvider { return ret; } - async releaseDevice(id: string, nativeId: string, device: any): Promise { + async releaseDevice(id: string, nativeId: string): Promise { } diff --git a/plugins/core/ui/package-lock.json b/plugins/core/ui/package-lock.json index 732b7952e..74df8a441 100644 --- a/plugins/core/ui/package-lock.json +++ b/plugins/core/ui/package-lock.json @@ -137,21 +137,22 @@ }, "../../../sdk": { "name": "@scrypted/sdk", - "version": "0.2.39", + "version": "0.2.55", "license": "ISC", "dependencies": { - "@babel/preset-typescript": "^7.16.7", + "@babel/preset-typescript": "^7.18.6", "adm-zip": "^0.4.13", "axios": "^0.21.4", - "babel-loader": "^8.2.3", + "babel-loader": "^9.1.0", "babel-plugin-const-enum": "^1.1.0", "esbuild": "^0.15.9", "ncp": "^2.0.0", "raw-loader": "^4.0.2", "rimraf": "^3.0.2", "tmp": "^0.2.1", - "typescript": "^4.9.3", - "webpack": "^5.74.0", + "ts-loader": "^9.4.2", + "typescript": "^4.9.4", + "webpack": "^5.75.0", "webpack-bundle-analyzer": "^4.5.0" }, "bin": { @@ -164,7 +165,7 @@ "scrypted-webpack": "bin/scrypted-webpack.js" }, "devDependencies": { - "@types/node": "^18.11.9", + "@types/node": "^18.11.18", "@types/stringify-object": "^4.0.0", "stringify-object": "^3.3.0", "ts-node": "^10.4.0", @@ -173,7 +174,7 @@ }, "../../../sdk/types": { "name": "@scrypted/types", - "version": "0.2.36", + "version": "0.2.52", "license": "ISC", "devDependencies": { "@types/rimraf": "^3.0.2", @@ -1967,7 +1968,7 @@ }, "node_modules/@fortawesome/fontawesome-common-types": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/fontawesome-common-types/-/6.2.1/fontawesome-common-types-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-common-types/-/6.2.1/fontawesome-common-types-6.2.1.tgz", "integrity": "sha512-Sz07mnQrTekFWLz5BMjOzHl/+NooTdW8F8kDQxjWwbpOJcnoSg4vUDng8d/WR1wOxM0O+CY9Zw0nR054riNYtQ==", "engines": { "node": ">=6" @@ -1975,7 +1976,7 @@ }, "node_modules/@fortawesome/fontawesome-free": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/fontawesome-free/-/6.2.1/fontawesome-free-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-free/-/6.2.1/fontawesome-free-6.2.1.tgz", "integrity": "sha512-viouXhegu/TjkvYQoiRZK3aax69dGXxgEjpvZW81wIJdxm5Fnvp3VVIP4VHKqX4SvFw6qpmkILkD4RJWAdrt7A==", "engines": { "node": ">=6" @@ -1983,7 +1984,7 @@ }, "node_modules/@fortawesome/fontawesome-svg-core": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/fontawesome-svg-core/-/6.2.1/fontawesome-svg-core-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-svg-core/-/6.2.1/fontawesome-svg-core-6.2.1.tgz", "integrity": "sha512-HELwwbCz6C1XEcjzyT1Jugmz2NNklMrSPjZOWMlc+ZsHIVk+XOvOXLGGQtFBwSyqfJDNgRq4xBCwWOaZ/d9DEA==", "dependencies": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -1994,7 +1995,7 @@ }, "node_modules/@fortawesome/free-brands-svg-icons": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/free-brands-svg-icons/-/6.2.1/free-brands-svg-icons-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/free-brands-svg-icons/-/6.2.1/free-brands-svg-icons-6.2.1.tgz", "integrity": "sha512-L8l4MfdHPmZlJ72PvzdfwOwbwcCAL0vx48tJRnI6u1PJXh+j2f3yDoKyQgO3qjEsgD5Fr2tQV/cPP8F/k6aUig==", "dependencies": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -2005,7 +2006,7 @@ }, "node_modules/@fortawesome/free-regular-svg-icons": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/free-regular-svg-icons/-/6.2.1/free-regular-svg-icons-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/free-regular-svg-icons/-/6.2.1/free-regular-svg-icons-6.2.1.tgz", "integrity": "sha512-wiqcNDNom75x+pe88FclpKz7aOSqS2lOivZeicMV5KRwOAeypxEYWAK/0v+7r+LrEY30+qzh8r2XDaEHvoLsMA==", "dependencies": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -2016,7 +2017,7 @@ }, "node_modules/@fortawesome/free-solid-svg-icons": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/free-solid-svg-icons/-/6.2.1/free-solid-svg-icons-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/free-solid-svg-icons/-/6.2.1/free-solid-svg-icons-6.2.1.tgz", "integrity": "sha512-oKuqrP5jbfEPJWTij4sM+/RvgX+RMFwx3QZCZcK9PrBDgxC35zuc7AOFsyMjMd/PIFPeB2JxyqDr5zs/DZFPPw==", "dependencies": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -22535,17 +22536,17 @@ }, "@fortawesome/fontawesome-common-types": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/fontawesome-common-types/-/6.2.1/fontawesome-common-types-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-common-types/-/6.2.1/fontawesome-common-types-6.2.1.tgz", "integrity": "sha512-Sz07mnQrTekFWLz5BMjOzHl/+NooTdW8F8kDQxjWwbpOJcnoSg4vUDng8d/WR1wOxM0O+CY9Zw0nR054riNYtQ==" }, "@fortawesome/fontawesome-free": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/fontawesome-free/-/6.2.1/fontawesome-free-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-free/-/6.2.1/fontawesome-free-6.2.1.tgz", "integrity": "sha512-viouXhegu/TjkvYQoiRZK3aax69dGXxgEjpvZW81wIJdxm5Fnvp3VVIP4VHKqX4SvFw6qpmkILkD4RJWAdrt7A==" }, "@fortawesome/fontawesome-svg-core": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/fontawesome-svg-core/-/6.2.1/fontawesome-svg-core-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-svg-core/-/6.2.1/fontawesome-svg-core-6.2.1.tgz", "integrity": "sha512-HELwwbCz6C1XEcjzyT1Jugmz2NNklMrSPjZOWMlc+ZsHIVk+XOvOXLGGQtFBwSyqfJDNgRq4xBCwWOaZ/d9DEA==", "requires": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -22553,7 +22554,7 @@ }, "@fortawesome/free-brands-svg-icons": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/free-brands-svg-icons/-/6.2.1/free-brands-svg-icons-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/free-brands-svg-icons/-/6.2.1/free-brands-svg-icons-6.2.1.tgz", "integrity": "sha512-L8l4MfdHPmZlJ72PvzdfwOwbwcCAL0vx48tJRnI6u1PJXh+j2f3yDoKyQgO3qjEsgD5Fr2tQV/cPP8F/k6aUig==", "requires": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -22561,7 +22562,7 @@ }, "@fortawesome/free-regular-svg-icons": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/free-regular-svg-icons/-/6.2.1/free-regular-svg-icons-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/free-regular-svg-icons/-/6.2.1/free-regular-svg-icons-6.2.1.tgz", "integrity": "sha512-wiqcNDNom75x+pe88FclpKz7aOSqS2lOivZeicMV5KRwOAeypxEYWAK/0v+7r+LrEY30+qzh8r2XDaEHvoLsMA==", "requires": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -22569,7 +22570,7 @@ }, "@fortawesome/free-solid-svg-icons": { "version": "6.2.1", - "resolved": "https://npm.fontawesome.com/@fortawesome/free-solid-svg-icons/-/6.2.1/free-solid-svg-icons-6.2.1.tgz", + "resolved": "https://registry.npmjs.org/@fortawesome/free-solid-svg-icons/-/6.2.1/free-solid-svg-icons-6.2.1.tgz", "integrity": "sha512-oKuqrP5jbfEPJWTij4sM+/RvgX+RMFwx3QZCZcK9PrBDgxC35zuc7AOFsyMjMd/PIFPeB2JxyqDr5zs/DZFPPw==", "requires": { "@fortawesome/fontawesome-common-types": "6.2.1" @@ -22800,12 +22801,12 @@ "@scrypted/sdk": { "version": "file:../../../sdk", "requires": { - "@babel/preset-typescript": "^7.16.7", - "@types/node": "^18.11.9", + "@babel/preset-typescript": "^7.18.6", + "@types/node": "^18.11.18", "@types/stringify-object": "^4.0.0", "adm-zip": "^0.4.13", "axios": "^0.21.4", - "babel-loader": "^8.2.3", + "babel-loader": "^9.1.0", "babel-plugin-const-enum": "^1.1.0", "esbuild": "^0.15.9", "ncp": "^2.0.0", @@ -22813,10 +22814,11 @@ "rimraf": "^3.0.2", "stringify-object": "^3.3.0", "tmp": "^0.2.1", + "ts-loader": "^9.4.2", "ts-node": "^10.4.0", "typedoc": "^0.23.21", - "typescript": "^4.9.3", - "webpack": "^5.74.0", + "typescript": "^4.9.4", + "webpack": "^5.75.0", "webpack-bundle-analyzer": "^4.5.0" } }, diff --git a/plugins/core/ui/src/common/DevicePicker.vue b/plugins/core/ui/src/common/DevicePicker.vue index feb41243a..0e1656764 100644 --- a/plugins/core/ui/src/common/DevicePicker.vue +++ b/plugins/core/ui/src/common/DevicePicker.vue @@ -1,6 +1,6 @@