UNPKG

@zeppos/zml

Version:

A Mini Library of ZeppOS MiniApp

2 lines (1 loc) 21.1 kB
const e=Object.prototype.hasOwnProperty,t={init(){this.plugins=[],this.settings={},this.mixins=[]},set(e,t){if(1===arguments.length)return this.settings[e];this.settings[e]=t},use(e,...t){return"function"==typeof e?this.plugins.push({handler:e,args:t}):"object"==typeof e&&this.mixins.push({handler:e,args:[]}),this},handle(e){this.plugins.forEach((t=>{if(t&&"function"==typeof t.handler)try{const s=t.handler.call(this,e,...t.args);"object"==typeof s&&this.mixins.push({handler:s,args:[]})}catch(e){}})),this.mixins.forEach((({handler:{onInit:t,onPause:s,build:n,onResume:i,onDestroy:r,onCreate:a,...o},args:h})=>{Object.assign(e,o)}))}},s={onChange(e){return e?(settings.settingsStorage.addListener("change",e),this):this},offChange(){return settings.settingsStorage.removeListener("change"),this},getItem:e=>settings.settingsStorage.getItem(e),setItem:(e,t)=>settings.settingsStorage.setItem(e,t),clear:()=>settings.settingsStorage.clear(),removeItem(e){settings.settingsStorage.removeItem(e)},getAll:()=>settings.settingsStorage.toObject()};function n({state:e={},onInit:t,onRun:s,onDestroy:i,...r}={}){const a={state:e,...r,onInit(e){for(let t=0;t<=n.mixins.length-1;t++){const s=n.mixins[t];s&&s.handler.onInit?.apply(this,e)}t?.apply(this,e)},onRun(e){for(let t=0;t<=n.mixins.length-1;t++){const s=n.mixins[t];s&&s.handler.onRun?.apply(this,e)}s?.apply(this,e)},onDestroy(e){i?.apply(this,e);for(let t=n.mixins.length-1;t>=0;t--){const s=n.mixins[t];s&&s.handler.onDestroy?.apply(this,e)}}};return n.handle(a),a}var i,r;function a(){return l()&&h()}function o(){return l()&&d()}function h(){return"undefined"!=typeof hmApp}function d(){return"undefined"!=typeof __$$R$$__}function l(){return h()||d()}i=n,r=t,Object.getOwnPropertyNames(r).forEach((function(t){if(!e.call(i,t)){var s=Object.getOwnPropertyDescriptor(r,t);Object.defineProperty(i,t,s)}})),n.init(),n.use((function(){return{onInit(){this.logger=Logger.getLogger(sideService.appInfo.app.appName),this.logger.scope=sideService.appInfo.app.appName,this.logger.name="side-service",this.log=(...e)=>{this.logger.log(...e)},this.error=(...e)=>{e[0]instanceof Error?this.logger.error(...e):this.logger.error({},...e)},this.debug=(...e)=>{this.logger.debug(...e)}}}})),n.use((function(){return{onInit(){this.settings=s,this._onSettingsChange=this.onSettingsChange?.bind(this),s.onChange(this._onSettingsChange),"undefined"!=typeof sideService&&sideService.launchReasons.settingsChanged&&this._onSettingsChange(sideService.launchArgs)},onDestroy(){this._onSettingsChange&&s.offChange(this._onSettingsChange)}}}));let c=null;c="undefined"!=typeof __$$R$$__?__$$R$$__:()=>({});let u=null;a()?u=DeviceRuntimeCore.HmLogger:o()?u=c("@zos/utils").log:"undefined"!=typeof messaging&&"undefined"!=typeof Logger&&(u=Logger);class p{constructor(){this.listeners=new Map}on(e,t){this.listeners.has(e)||this.listeners.set(e,[]),this.listeners.get(e).push(t)}off(e,t){if(e)if(t){const s=this.listeners.get(e);if(!s)return;const n=s.findIndex((e=>e===t));n>=0&&s.splice(n,1)}else this.listeners.delete(e)}emit(e,...t){for(let s of this.listeners.get(e)??[])s&&s(...t)}clear(){this.listeners.clear()}once(e,t){const s=(...n)=>{this.off(e,s),t(...n)};this.on(e,s)}count(e){return(this.listeners.get(e)??[]).length}}const f=setTimeout,g=clearTimeout,y=Promise;function m(){const e={canceled:!1};return e.promise=new y((function(t,s){e.resolve=t,e.reject=s})),e.cancel=()=>{e.canceled=!0,e.reject(new Error("Task canceled"))},e}let I=null;a()?I=hmBle:o()&&(I=c("@zos/ble"));const T=Buffer;function b(e){return k(function(e){return JSON.stringify(e)}(e))}function S(e){return t=w(e),JSON.parse(t);var t}function k(e){return T.from(e,"utf-8")}function w(e){return e.toString("utf-8")}function L(e){return e.buffer.slice(e.byteOffset,e.byteOffset+e.byteLength)}function v(e){return t=function(e){return T.from(e)}(e),t.toString("hex");var t}function C(e){return"object"==typeof e&&!T.isBuffer(e)&&!Array.isArray(e)&&null!==e}const q=l()?u.getLogger("device-message"):u.getLogger("side-message"),U=void 0,B="json",E="text",x="bin";function R(e){switch(e.toLowerCase()){case B:return 2;case E:return 1;case x:return 3;case"empty":return 0;default:return 3}}let P=1e4;function D(){return P++}let j=1e3;function O(){return j++}class _ extends p{constructor(e,t,s,n){super(),this.id=e,this.type=t,this.ctx=n,this.chunks=[],this.count=-1,this.finishChunk=null,this.size=s,this.receivedSize=0}addChunk(e){this.receivedSize+=e.payloadLength,1===e.opCode&&(this.count=e.seqId+1,this.finishChunk=e),e.payloadLength===e.payload.byteLength?(this.chunks.push(e),this.checkIfReceiveAllChunks()):this.emit("error",Error(`receive chunk data length error, expect ${e.payloadLength} but ${e.payload.byteLength}`))}checkIfReceiveAllChunks(){if(this.count!==this.chunks.length)return;if(!this.finishChunk)return;if(this.size!==this.receivedSize)return;this.chunks.sort(((e,t)=>e.seqId-t.seqId));let e=[];for(let t=0;t<this.count;t++){const s=this.chunks[t];if(!s||s.seqId!==t)return e=null,this.releaseBuf(),void this.emit("error",Error("receive data error"));e.push(s.payload)}this.chunks=[],this.finishChunk.payload=T.concat(e),e=null,this.finishChunk.payloadLength=this.finishChunk.payload.byteLength,this.finishChunk.totalLength===this.finishChunk.payloadLength?this.emit("data",this.finishChunk):this.emit("error",Error(`receive full data length error, expect ${this.finishChunk.payloadLength} but ${this.finishChunk.payload.byteLength}`))}releaseBuf(){this.chunks=[],this.finishChunk=null,this.count=0,this.size=0,this.receivedSize=0}}class F{constructor(){this.sessions=new Map}key(e){return`${e.id}:${e.type}`}newSession(e,t,s,n){const i=new _(e,t,s,n);return this.sessions.set(this.key(i),i),i}destroy(e){e.releaseBuf(),this.sessions.delete(this.key(e))}has(e,t){return this.sessions.has(this.key({id:e,type:t}))}getById(e,t){return this.sessions.get(this.key({id:e,type:t}))}clear(){this.sessions.clear()}}class A extends Error{constructor(e,t){super(t),this.code=e,this.reason=t}}class ${constructor(){this.set=new Set}add(e){this.set.add(e)}runAll(...e){this.set.forEach((t=>{t&&t(...e)}))}remove(e){e?this.set.delete(e):this.set.clear()}}u.getLogger("message-builder");const z="hmrpcv1",M=new $,H=new $,N=new $,J=new class extends p{constructor({appId:e=0,appDevicePort:t=20,appSidePort:s=0,ble:n=(l()?I:void 0)}={appId:0,appDevicePort:20,appSidePort:0,ble:l()?I:void 0}){super(),this.isDevice=l(),this.isSide=!this.isDevice,this.appId=e,this.appDevicePort=t,this.appSidePort=s,this.ble=n,this.sendMsg=this.getSafeSend(),this.chunkSize=3584,this.handlers=new Map,this.shakeTask=null,this.waitingShakePromise=null,this.shakeStatus=1,this.shakeTimer=0,this.sessionMgr=new F,this.on("response",(e=>{this.onResponse(e)})),n?.addListener((e=>{this.emit("bleStatusChanged",e)})),this.on("bleStatusChanged",(e=>{if(!e){q.error("ble disconnect"),this.shakeTask&&(this.shakeTask.reject(new A(2,"ble disconnect")),this.shakeStatus=4);for(const[e,t]of Object.entries(this.handlers))t.task.reject(new A(2,"ble disconnect"));this.handlers.clear()}}))}fork(e=5e3){if(2===this.shakeStatus)return this.waitingShakePromise;this.shakeTask=m(),this.waitingShakePromise=this.shakeTask.promise,this.shakeStatus=1,this.clearShakeTimer(),this.shakeTimer=f((()=>{this.shakeStatus=4,this.shakeTask.reject(new A(1,"shake timeout"))}),e);try{this.errorIfBleDisconnect()}catch(e){return q.error("error ble disconnect %j",e),this.shakeTask.reject(new A(2,"ble disconnect")),this.shakeStatus=4,this.waitingShakePromise}return this.shakeStatus=2,this.sendShake(),this.waitingShakePromise}clearShakeTimer(){this.shakeTimer&&g(this.shakeTimer),this.shakeTimer=0}getMessageSize(){return 3600}getMessagePayloadSize(){return 3584}getMessageHeaderSize(){return 16}buf2Json(e){return S(e)}json2Buf(e){return b(e)}now(e=Date.now()){return function(e=Date.now()){return e%1e7}(e)}connect(e){this.on("message",(e=>{this.onMessage(e)})),this.ble&&this.ble.createConnect(((e,t,s)=>{this.onFragmentData(t)})),e&&e(this)}disConnect(e){this.sendClose(),this.off("message"),this.handlers.clear(),this.ble&&this.ble.disConnect(),e&&e(this)}listen(e){this.appSidePort=globalThis.getApp().port2,messaging&&messaging.peerSocket.addListener("message",(e=>{this.onMessage(e)})),this.waitingShakePromise=y.resolve(),e&&e(this)}buildBin(e){if(e.payload.byteLength>this.chunkSize)throw new Error(`${e.payload.byteLength} greater than max size of ${this.chunkSize}`);const t=this.getMessageHeaderSize()+e.payload.byteLength;let s=T.alloc(t),n=0;return s.writeUInt8(e.flag,n),n+=1,s.writeUInt8(e.version,n),n+=1,s.writeUInt16LE(e.type,n),n+=2,s.writeUInt16LE(e.port1,n),n+=2,s.writeUInt16LE(e.port2,n),n+=2,s.writeUInt32LE(e.appId,n),n+=4,s.writeUInt32LE(e.extra,n),n+=4,s.fill(e.payload,n,e.payload.byteLength+n),s}buildShake(){return this.buildBin({flag:1,version:1,type:1,port1:this.appDevicePort,port2:this.appSidePort,appId:this.appId,extra:0,payload:T.from([this.appId])})}sendShake(){q.info("shake send");const e=this.buildShake();this.sendMsg(e)}buildClose(){return this.buildBin({flag:1,version:1,type:2,port1:this.appDevicePort,port2:this.appSidePort,appId:this.appId,extra:0,payload:T.from([this.appId])})}sendClose(){const e=this.buildClose();this.sendMsg(e)}readBin(e){const t=T.from(e);let s=0;const n=t.readUInt8(s);s+=1;const i=t.readUInt8(s);s+=1;const r=t.readUInt16LE(s);s+=2;const a=t.readUInt16LE(s);s+=2;const o=t.readUInt16LE(s);s+=2;const h=t.readUInt32LE(s);s+=4;const d=t.readUInt32LE(s);return s+=4,{flag:n,version:i,type:r,port1:a,port2:o,appId:h,extra:d,payload:t.subarray(s)}}buildData(e,t={}){return this.buildBin({flag:1,version:1,type:4,port1:this.appDevicePort,port2:this.appSidePort,appId:this.appId,extra:0,...t,payload:e})}sendBin(e,t=U){if(t&&q.warn("[RAW] [S] send size=%d bin=%s",e.byteLength,v(e.buffer)),!this.ble.send(e.buffer,e.byteLength))throw Error("send message error")}sendBinBySide(e,t=U){t&&q.warn("[RAW] [S] send size=%d bin=%s",e.byteLength,v(e.buffer)),messaging.peerSocket.send(e.buffer)}getSafeSend(){return this.isDevice?this.sendBin.bind(this):this.sendBinBySide.bind(this)}sendHmProtocol({requestId:e,dataBin:t,type:s,contentType:n,dataType:i},{messageType:r=4}={}){const a=3518,o=t.byteLength;let h=0;const d=T.alloc(a),l=e||D(),c=O();let u=0;const p=Math.ceil(o/a);function f(){return u++}for(let e=1;e<=p;e++){if(this.errorIfBleDisconnect(),e===p){const e=o-h,a=T.alloc(0+e);t.copy(a,0,h,h+e),h+=e,this.sendDataWithSession({traceId:l,spanId:c,seqId:f(),payload:a,type:s,opCode:1,totalLength:o,contentType:n,dataType:i},{messageType:r});break}t.copy(d,0,h,h+a),h+=a,this.sendDataWithSession({traceId:l,spanId:c,seqId:f(),payload:d,type:s,opCode:0,totalLength:o,contentType:n,dataType:i},{messageType:r})}}sendJson({requestId:e=0,json:t,type:s=1,contentType:n,dataType:i}){const r=b(t),a=e||D();this.sendHmProtocol({requestId:a,dataBin:r,type:s,contentType:n,dataType:i})}sendBuf({requestId:e=0,buf:t,type:s=1,contentType:n,dataType:i}){const r=e||D();return this.sendHmProtocol({requestId:r,dataBin:t,type:s,contentType:n,dataType:i})}sendText({requestId:e=0,text:t,type:s=1,contentType:n,dataType:i}){const r=k(t),a=e||D();return this.sendHmProtocol({requestId:a,dataBin:r,type:s,contentType:n,dataType:i})}sendDataWithSession({traceId:e,spanId:t,seqId:s,payload:n,type:i,opCode:r,totalLength:a,contentType:o,dataType:h},{messageType:d}){const l=this.buildPayload({traceId:e,spanId:t,seqId:s,totalLength:a,type:i,opCode:r,payload:n,contentType:o,dataType:h});let c=this.isDevice?this.buildData(l,{type:d}):l;this.sendMsg(c)}buildPayload(e){const t=66+e.payload.byteLength;let s=T.alloc(t),n=0;return s.writeUInt32LE(e.traceId,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(e.spanId,n),n+=4,s.writeUInt32LE(e.seqId,n),n+=4,s.writeUInt32LE(e.totalLength,n),n+=4,s.writeUInt32LE(e.payload.byteLength,n),n+=4,s.writeUInt8(e.type,n),n+=1,s.writeUInt8(e.opCode,n),n+=1,s.writeUInt32LE(this.now(),n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.writeUInt8(e.contentType,n),n+=1,s.writeUInt8(e.dataType,n),n+=1,s.writeUInt16LE(0,n),n+=2,s.writeUInt32LE(0,n),n+=4,s.writeUInt32LE(0,n),n+=4,s.fill(e.payload,n,e.payload.byteLength+n),s}readPayload(e){const t=T.from(e);let s=0;const n=t.readUInt32LE(s);s+=4;const i=t.readUInt32LE(s);s+=4;const r=t.readUInt32LE(s);s+=4;const a=t.readUInt32LE(s);s+=4;const o=t.readUInt32LE(s);s+=4;const h=t.readUInt32LE(s);s+=4;const d=t.readUInt8(s);s+=1;const l=t.readUInt8(s);s+=1;const c=t.readUInt32LE(s);s+=4;const u=t.readUInt32LE(s);s+=4;const p=t.readUInt32LE(s);s+=4;const f=t.readUInt32LE(s);s+=4;const g=t.readUInt32LE(s);s+=4;const y=t.readUInt32LE(s);s+=4;const m=t.readUInt32LE(s);s+=4;const I=t.readUInt8(s);s+=1;const b=t.readUInt8(s);s+=1;const S=t.readUInt16LE(s);s+=2;const k=t.readUInt32LE(s);s+=4;const w=t.readUInt32LE(s);return s+=4,{traceId:n,parentId:i,spanId:r,seqId:a,totalLength:o,payloadLength:h,payloadType:d,opCode:l,contentType:I,dataType:b,timestamp1:c,timestamp2:u,timestamp3:p,timestamp4:f,timestamp5:g,timestamp6:y,timestamp7:m,extra1:S,extra2:k,extra3:w,payload:t.subarray(s)}}onFragmentData(e){const t=this.readBin(e);this.emit("raw",e),1===t.flag&&1===t.type?(this.appSidePort=t.port2,q.info("shake success appSidePort=>",t.port2),this.emit("shake:response",t),this.clearShakeTimer(),this.shakeTask.resolve(),this.shakeStatus=3):1===t.flag&&4===t.type||1===t.flag&&5===t.type?(this.emit("message",t.payload),this.emit("read",t)):1===t.flag&&6===t.type?this.emit("log",t.payload):0===t.flag||1===t.flag&&2===t.type&&(this.appSidePort=0)}errorIfBleDisconnect(){if(l()&&!this.ble.connectStatus())throw new A(2,"ble disconnect")}errorIfSideServiceDisconnect(){if(l()&&!this.appSidePort)throw new A(3,"side service is not running")}getRequestCount(){return this.handlers.size}onResponse(e){const t=this.handlers.get(e.traceId).handler;t&&t(e)}onMessage(e){const t=this.readPayload(e);let s=this.sessionMgr.getById(t.traceId,t.payloadType);s||(s=this.sessionMgr.newSession(t.traceId,t.payloadType,t.totalLength,this),s.on("data",(e=>{1===e.opCode&&(1===e.payloadType?this.emit("request",{request:e,response:({data:t,dataType:s})=>{s=void 0!==s?R(s):e.dataType,this.response({requestId:e.traceId,contentType:e.contentType,dataType:s,data:t})}}):2===e.payloadType?this.emit("response",e):3===e.payloadType&&this.emit("call",e),this.emit("data",e),this.sessionMgr.destroy(s))})),s.on("error",(e=>{this.sessionMgr.destroy(s),this.emit("error",e)}))),s.addChunk(t)}request(e,t){try{this.errorIfBleDisconnect()}catch(e){return q.error("error ble disconnect %j",e),y.reject(e)}return this.waitingShakePromise.then((()=>{this.errorIfBleDisconnect(),this.errorIfSideServiceDisconnect();let s=x;"string"==typeof e?s=E:C(e)?s=B:(e instanceof ArrayBuffer||ArrayBuffer.isView(e)||T.isBuffer(e))&&(s=x);const n={timeout:6e4,contentType:s,dataType:s},i=D(),r=m();t=Object.assign(n,t);let a=f((()=>{a=null,r.reject(new A(4,`request id=${i} timeout in ${t.timeout}ms`))}),t.timeout);return this.handlers.set(i,{handler:({traceId:e,payload:t,dataType:s})=>{let n;switch(this.errorIfBleDisconnect(),this.errorIfSideServiceDisconnect(),s){case 1:n=w(t);break;case 3:default:n=t;break;case 2:n=S(t)}q.info("response id=>%d",i),r.resolve(n)},task:r}),q.info("request id=%d",i),T.isBuffer(e)?this.sendBuf({requestId:i,buf:e,type:1,contentType:3,dataType:R(t.dataType)}):e instanceof ArrayBuffer||ArrayBuffer.isView(e)?this.sendBuf({requestId:i,buf:T.from(e),type:1,contentType:3,dataType:R(t.dataType)}):2===R(t.contentType)?this.sendJson({requestId:i,json:e,type:1,contentType:2,dataType:R(t.dataType)}):1===R(t.contentType)?this.sendText({requestId:i,text:e,type:1,contentType:1,dataType:R(t.dataType)}):this.sendBuf({requestId:i,buf:T.from(e),type:1,contentType:3,dataType:R(t.dataType)}),r.promise.catch((e=>{throw q.error("request id=%d %d %j",i,e.code,e.reason),e})).finally((()=>{a&&(g(a),a=null),this.handlers.get(i)?this.handlers.delete(i):q.warn("release request id=>%d error",i)}))}))}response({requestId:e,contentType:t,dataType:s,data:n}){3===s?this.sendBuf({requestId:e,buf:n,type:2,contentType:t,dataType:s}):1===s?this.sendText({requestId:e,text:n,type:2,contentType:t,dataType:s}):2===s?this.sendJson({requestId:e,json:n,type:2,contentType:t,dataType:s}):this.sendBuf({requestId:e,buf:n,type:2,contentType:t,dataType:3})}call(e){let t=2;return"string"==typeof e?t=1:C(e)?t=2:(e instanceof ArrayBuffer||ArrayBuffer.isView(e)||T.isBuffer(e))&&(t=3),this.waitingShakePromise.then((()=>T.isBuffer(e)?this.sendBuf({buf:e,type:3,contentType:3,dataType:0}):e instanceof ArrayBuffer||ArrayBuffer.isView(e)?this.sendBuf({buf:T.from(e),type:3,contentType:3,dataType:0}):2===t?this.sendJson({json:e,type:3,contentType:2,dataType:0}):1===t?this.sendText({text:e,type:3,contentType:1,dataType:0}):this.sendBuf({buf:T.from(e),type:3,contentType:3,dataType:0})))}},W=function(e){return{shakeTimeout:5e3,requestTimeout:6e4,transport:e,onCall(e){return e?(M.add(e),this):this},offOnCall(e){return M.remove(e),this},call(t){return l()&&e.fork(this.shakeTimeout),t=C(t)?t.contentType?t:{jsonrpc:z,...t}:t,e.call(t)},onRequest(e){return e?(H.add(e),this):this},initOnCall(){e.on("call",(({contentType:e,payload:t})=>{switch(e){case 2:t=S(t);break;case 1:t=w(t);break;default:t=L(t)}M.runAll(t)}))},initOnRequest(){e.on("request",(e=>{let t=e.request.payload;switch(e.request.contentType){case 2:t=S(t);break;case 1:t=w(t);break;default:t=L(t)}H.runAll(t,((s,n,i={})=>2===e.request.contentType&&t?.jsonrpc===z?s?e.response({data:{jsonrpc:z,error:s}}):e.response({data:{jsonrpc:z,result:n}}):e.response({data:n,...i})))}))},cancelAllRequest(){return e.off("response"),this},offOnRequest(e){return H.remove(e),this},request(t,s={}){return l()&&e.fork(this.shakeTimeout),t=C(t)?s.contentType?t:{jsonrpc:z,...t}:t,e.request(t,{timeout:this.requestTimeout,...s}).then((e=>{if(!C(e)||e.jsonrpc!==z)return e;const{error:t,result:s}=e;if(t)throw t;return s}))},connect(){e.connect((()=>{this.initOnCall(),this.initOnRequest(),this.initOnBleChanged()}))},initOnBleChanged(){return e.on("bleStatusChanged",(e=>{N.runAll(e)})),this},onBleChanged(e){return e?(N.add(e),this):this},offOnBleChanged(e){return N.remove(e),this},disConnect(){return this.cancelAllRequest(),this.offOnRequest(),this.offOnCall(),this.offOnBleChanged(),e.disConnect((()=>{})),this},start(){return e.listen((()=>{this.initOnCall(),this.initOnRequest()})),this},stop(){return this.cancelAllRequest(),this.offOnRequest(),this.offOnCall(),e.disConnect((()=>{})),this}}}(J);function V(e){return e.toTimeString().split(" ")[0]}const G=function(e){let t=new $;return{canUseFileTransfer:()=>void 0!==e,onFile(s){return s&&this.canUseFileTransfer()?(t.add(s),e.inbox.on("newfile",(function(){const s=e.inbox.getNextFile();t.runAll(s)})),this):this},onSideServiceFileFinished(s){return s&&this.canUseFileTransfer()?(t.add(s),e.inbox.on("file",(function(){const s=e.inbox.getNextFile();t.runAll(s)})),this):this},emitFile(){return e.inbox.emit("file"),this},offFile(){return this.canUseFileTransfer()?(e.inbox.off("newfile"),e.inbox.off("file"),t.remove(),this):this},getFile(){return this.canUseFileTransfer()?e.inbox.getNextFile():null},sendFile(t,s){if(!this.canUseFileTransfer())throw new Error("fileTransfer is not available");return e.outbox.enqueueFile(t,s)}}}(transferFile),K={convert:e=>image.convert(e)};n.use((function(){return{onInit(){this.messaging=W,this._onCall=this.onCall?.bind(this),this._onRequest=this.onRequest?.bind(this),this.messaging.onCall(this._onCall).onRequest(this.__onRequest.bind(this)),this.messaging.start()},onDestroy(){this._onCall&&this.messaging.offOnCall(this._onCall),this._onRequest&&this.messaging.offOnRequest(this._onRequest),this.messaging.stop()},request(e,t={}){return this.messaging.request(e,t)},call(e){return this.messaging.call(e)},__onRequest(e,t){return"http.request"===e.method?this.httpRequestHandler(e,t):this._onRequest(e,t)},fetch:e=>fetch(function(e){const t={timeout:1e4,...e};return t.baseURL&&(t.url=new URL(t.url,t.baseURL).toString()),t}(e)),httpRequestHandler(e,t){const s=new Date;return this.fetch(e.params).then((e=>{t(null,{status:e.status,statusText:e.statusText,headers:e.headers,body:e.body})})).catch((s=>(this.error("http error url=%s",e.params.url,s.message,s.data),t({code:s.code,message:s.message,data:s.data})))).finally((()=>{const t=new Date;this.log("http url=%s %s %s elapsed=%dms",e.params.url,V(s),V(t),t.getTime()-s.getTime())}))}}})).use((function(){return{onInit(){this._onReceivedFile=this.onReceivedFile?.bind(this),G.onSideServiceFileFinished(this._onReceivedFile),"undefined"!=typeof sideService&&sideService.launchReasons.fileTransfer&&G.emitFile()},onDestroy(){this._onReceivedFile&&G.offFile(this._onReceivedFile)},sendFile:(e,t)=>G.sendFile(e,t)}})).use((function(e){e.download=function(e,t){return network.downloader.downloadFile({url:e,...t})}})).use((function(e){e.convert=function(e){return K.convert(e)}}));export{n as BaseSideService,K as convertLib,s as settingsLib};