@chatie/angular
Advanced tools
Comparing version 0.7.3 to 0.7.4
@@ -311,3 +311,3 @@ (function (global, factory) { | ||
*/ | ||
var VERSION = '0.7.3'; | ||
var VERSION = '0.7.4'; | ||
@@ -342,4 +342,4 @@ var ReadyState; | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
@@ -357,14 +357,14 @@ this.log.verbose('IoService', 'init()'); | ||
this.state.setLog(this.log); | ||
_a.label = 1; | ||
_b.label = 1; | ||
case 1: | ||
_a.trys.push([1, 4, , 5]); | ||
_b.trys.push([1, 4, , 5]); | ||
return [4 /*yield*/, this.initStateDealer()]; | ||
case 2: | ||
_a.sent(); | ||
_b.sent(); | ||
return [4 /*yield*/, this.initRxSocket()]; | ||
case 3: | ||
_a.sent(); | ||
_b.sent(); | ||
return [3 /*break*/, 5]; | ||
case 4: | ||
e_1 = _a.sent(); | ||
e_1 = _b.sent(); | ||
this.log.silly('IoService', 'init() exception: %s', e_1.message); | ||
@@ -398,4 +398,4 @@ throw e_1; | ||
var e_2; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
@@ -414,12 +414,12 @@ this.log.verbose('IoService', 'start() with token:%s', this._token); | ||
this.autoReconnect = true; | ||
_a.label = 1; | ||
_b.label = 1; | ||
case 1: | ||
_a.trys.push([1, 3, , 4]); | ||
_b.trys.push([1, 3, , 4]); | ||
return [4 /*yield*/, this.connectRxSocket()]; | ||
case 2: | ||
_a.sent(); | ||
_b.sent(); | ||
this.state.on(true); | ||
return [3 /*break*/, 4]; | ||
case 3: | ||
e_2 = _a.sent(); | ||
e_2 = _b.sent(); | ||
this.log.warn('IoService', 'start() failed:%s', e_2.message); | ||
@@ -435,4 +435,4 @@ this.state.off(true); | ||
return __awaiter(this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
@@ -454,3 +454,3 @@ this.log.verbose('IoService', 'stop()'); | ||
case 1: | ||
_a.sent(); | ||
_b.sent(); | ||
this.state.off(true); | ||
@@ -465,18 +465,18 @@ return [2 /*return*/]; | ||
var e_3; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
this.log.verbose('IoService', 'restart()'); | ||
_a.label = 1; | ||
_b.label = 1; | ||
case 1: | ||
_a.trys.push([1, 4, , 5]); | ||
_b.trys.push([1, 4, , 5]); | ||
return [4 /*yield*/, this.stop()]; | ||
case 2: | ||
_a.sent(); | ||
_b.sent(); | ||
return [4 /*yield*/, this.start()]; | ||
case 3: | ||
_a.sent(); | ||
_b.sent(); | ||
return [3 /*break*/, 5]; | ||
case 4: | ||
e_3 = _a.sent(); | ||
e_3 = _b.sent(); | ||
this.log.error('IoService', 'restart() error:%s', e_3.message); | ||
@@ -507,3 +507,3 @@ throw e_3; | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
return __generator(this, function (_b) { | ||
this.log.verbose('IoService', 'initRxSocket()'); | ||
@@ -534,3 +534,3 @@ if (this.event) { | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
return __generator(this, function (_b) { | ||
this.log.verbose('IoService', 'connectRxSocket()'); | ||
@@ -599,3 +599,3 @@ // FIXME: check & close the old one | ||
var e; | ||
return __generator(this, function (_a) { | ||
return __generator(this, function (_b) { | ||
this.log.verbose('IoService', 'ding(%s)', payload); | ||
@@ -613,3 +613,3 @@ e = { | ||
return __awaiter(this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
return __generator(this, function (_b) { | ||
this.event.next({ | ||
@@ -632,4 +632,4 @@ name: 'update', | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
@@ -648,3 +648,3 @@ this.log.verbose('IoService', 'socketClose()'); | ||
case 1: | ||
_a.sent(); | ||
_b.sent(); | ||
return [2 /*return*/]; | ||
@@ -681,3 +681,4 @@ } | ||
IoService.prototype.socketUpdateState = function () { | ||
this.log.verbose('IoService', 'socketUpdateState() is %s', ReadyState[this._websocket.readyState]); | ||
var _a; | ||
this.log.verbose('IoService', 'socketUpdateState() is %s', ReadyState[(_a = this._websocket) === null || _a === void 0 ? void 0 : _a.readyState]); | ||
if (!this._websocket) { | ||
@@ -732,13 +733,13 @@ this.log.error('IoService', 'socketUpdateState() no _websocket'); | ||
var e_4; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
_a.trys.push([0, 2, , 3]); | ||
_b.trys.push([0, 2, , 3]); | ||
return [4 /*yield*/, this.connectRxSocket()]; | ||
case 1: | ||
_a.sent(); | ||
_b.sent(); | ||
this.state.on(true); | ||
return [3 /*break*/, 3]; | ||
case 2: | ||
e_4 = _a.sent(); | ||
e_4 = _b.sent(); | ||
this.log.warn('IoService', 'socketOnClose() autoReconnect() exception: %s', e_4); | ||
@@ -745,0 +746,0 @@ this.state.off(true); |
@@ -15,3 +15,3 @@ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("rxjs/operators"),require("brolog"),require("state-switch")):"function"==typeof define&&define.amd?define("@chatie/angular",["exports","@angular/core","rxjs","rxjs/operators","brolog","state-switch"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).chatie=e.chatie||{},e.chatie.angular={}),e.ng.core,e.rxjs,e.rxjs.operators,e.brolog,e.stateSwitch)}(this,(function(e,t,o,n,s,i){"use strict"; | ||
PERFORMANCE OF THIS SOFTWARE. | ||
***************************************************************************** */function r(e,t,o,n){return new(o||(o=Promise))((function(s,i){function r(e){try{c(n.next(e))}catch(e){i(e)}}function a(e){try{c(n.throw(e))}catch(e){i(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(r,a)}c((n=n.apply(e,t||[])).next())}))}function a(e,t){var o,n,s,i,r={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]};return i={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(i){return function(a){return function(i){if(o)throw new TypeError("Generator is already executing.");for(;r;)try{if(o=1,n&&(s=2&i[0]?n.return:i[0]?n.throw||((s=n.return)&&s.call(n),0):n.next)&&!(s=s.call(n,i[1])).done)return s;switch(n=0,s&&(i=[2&i[0],s.value]),i[0]){case 0:case 1:s=i;break;case 4:return r.label++,{value:i[1],done:!1};case 5:r.label++,n=i[1],i=[0];continue;case 7:i=r.ops.pop(),r.trys.pop();continue;default:if(!(s=r.trys,(s=s.length>0&&s[s.length-1])||6!==i[0]&&2!==i[0])){r=0;continue}if(3===i[0]&&(!s||i[1]>s[0]&&i[1]<s[3])){r.label=i[1];break}if(6===i[0]&&r.label<s[1]){r.label=s[1],s=i;break}if(s&&r.label<s[2]){r.label=s[2],r.ops.push(i);break}s[2]&&r.ops.pop(),r.trys.pop();continue}i=t.call(e,r)}catch(e){i=[6,e],n=0}finally{o=s=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,a])}}}Object.create;Object.create;var c,h="0.7.3";!function(e){e[e.CLOSED=WebSocket.CLOSED]="CLOSED",e[e.CLOSING=WebSocket.CLOSING]="CLOSING",e[e.CONNECTING=WebSocket.CONNECTING]="CONNECTING",e[e.OPEN=WebSocket.OPEN]="OPEN"}(c||(c={}));var u=function(){function e(){this.autoReconnect=!0,this.log=s.Brolog.instance(),this.CONNECT_TIMEOUT=1e4,this.ENDPOINT="wss://api.chatie.io/v0/websocket/token/",this.PROTOCOL="web|0.0.1",this.sendBuffer=[],this.log.verbose("IoService","constructor()")}return Object.defineProperty(e.prototype,"readyState",{get:function(){return this._readyState.asObservable()},enumerable:!1,configurable:!0}),e.prototype.init=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(n){switch(n.label){case 0:if(this.log.verbose("IoService","init()"),this.state)throw new Error("re-init");this.snapshot={readyState:c.CLOSED,event:null},this._readyState=new o.BehaviorSubject(c.CLOSED),this.state=new i.StateSwitch("IoService",this.log),this.state.setLog(this.log),n.label=1;case 1:return n.trys.push([1,4,,5]),[4,this.initStateDealer()];case 2:return n.sent(),[4,this.initRxSocket()];case 3:return n.sent(),[3,5];case 4:throw e=n.sent(),this.log.silly("IoService","init() exception: %s",e.message),e;case 5:return this.readyState.subscribe((function(e){t.log.silly("IoService","init() readyState.subscribe(%s)",c[e]),t.snapshot.readyState=e})),this.event.subscribe((function(e){t.log.silly("IoService","init() event.subscribe({name:%s})",e.name),t.snapshot.event=e})),[2]}}))}))},e.prototype.token=function(e){if(this.log.silly("IoService","token(%s)",e),!e)return this._token;this._token=e},e.prototype.start=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:if(this.log.verbose("IoService","start() with token:%s",this._token),!this._token)throw new Error("start() without token");if(this.state.on())throw new Error("state is already ON");if(this.state.pending())throw new Error("state is pending");this.state.on("pending"),this.autoReconnect=!0,t.label=1;case 1:return t.trys.push([1,3,,4]),[4,this.connectRxSocket()];case 2:return t.sent(),this.state.on(!0),[3,4];case 3:return e=t.sent(),this.log.warn("IoService","start() failed:%s",e.message),this.state.off(!0),[3,4];case 4:return[2]}}))}))},e.prototype.stop=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:if(this.log.verbose("IoService","stop()"),this.state.off()){if(this.log.warn("IoService","stop() state is already off"),this.state.pending())throw new Error("state pending() is true");return[2]}if(this.state.off("pending"),this.autoReconnect=!1,!this._websocket)throw new Error("no websocket");return[4,this.socketClose(1e3,"IoService.stop()")];case 1:return e.sent(),this.state.off(!0),[2]}}))}))},e.prototype.restart=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:this.log.verbose("IoService","restart()"),t.label=1;case 1:return t.trys.push([1,4,,5]),[4,this.stop()];case 2:return t.sent(),[4,this.start()];case 3:return t.sent(),[3,5];case 4:throw e=t.sent(),this.log.error("IoService","restart() error:%s",e.message),e;case 5:return[2]}}))}))},e.prototype.initStateDealer=function(){var e=this;this.log.verbose("IoService","initStateDealer()");this.readyState.pipe(n.filter((function(e){return e===c.OPEN}))).subscribe((function(t){return e.stateOnOpen()}))},e.prototype.initRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(s){if(this.log.verbose("IoService","initRxSocket()"),this.event)throw new Error("re-init is not permitted");return this.moObserver={next:this.socketSend.bind(this),error:this.socketClose.bind(this),complete:this.socketClose.bind(this)},e=new o.Observable((function(e){return t.log.verbose("IoService","initRxSocket() Observable.create()"),t.mtObserver=e,t.socketClose.bind(t)})),this.event=o.Subject.create(this.moObserver,e.pipe(n.share())),[2]}))}))},e.prototype.connectRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(o){if(this.log.verbose("IoService","connectRxSocket()"),this._websocket)throw new Error("already has a websocket");if(this.state.off())throw new Error("switch state is off");if(!this.state.pending())throw new Error("switch state is already ON");return this._websocket=new WebSocket(this.endPoint(),this.PROTOCOL),this.socketUpdateState(),e=new Promise((function(e,o){t.log.verbose("IoService","connectRxSocket() Promise()");var n=setTimeout((function(){t._websocket=null;var e=new Error("rxSocket connect timeout after "+Math.round(t.CONNECT_TIMEOUT/1e3));o(e)}),t.CONNECT_TIMEOUT);t._websocket.onopen=function(o){t.log.verbose("IoService","connectRxSocket() Promise() WebSocket.onOpen() resolve()"),t.socketUpdateState(),clearTimeout(n),e()}})),this._websocket.onmessage=this.socketOnMessage.bind(this),this._websocket.onerror=this.socketOnError.bind(this),this._websocket.onclose=this.socketOnClose.bind(this),[2,e]}))}))},e.prototype.endPoint=function(){var e=this.ENDPOINT+this._token;return this.log.verbose("IoService","endPoint() => %s",e),e},e.prototype.stateOnOpen=function(){this.log.verbose("IoService","stateOnOpen()"),this.socketSendBuffer(),this.rpcUpdate("from stateOnOpen()")},e.prototype.rpcDing=function(e){return r(this,void 0,void 0,(function(){var t;return a(this,(function(o){return this.log.verbose("IoService","ding(%s)",e),t={name:"ding",payload:e},this.event.next(t),[2]}))}))},e.prototype.rpcUpdate=function(e){return r(this,void 0,void 0,(function(){return a(this,(function(t){return this.event.next({name:"update",payload:e}),[2]}))}))},e.prototype.socketClose=function(e,t){return r(this,void 0,void 0,(function(){var o=this;return a(this,(function(s){switch(s.label){case 0:if(this.log.verbose("IoService","socketClose()"),!this._websocket)throw new Error("no websocket");return this._websocket.close(e,t),this.socketUpdateState(),[4,new Promise((function(e){o.readyState.pipe(n.filter((function(e){return e===c.CLOSED}))).subscribe(e)}))];case 1:return s.sent(),[2]}}))}))},e.prototype.socketSend=function(e){this.log.silly("IoService","socketSend({name:%s, payload:%s})",e.name,e.payload),this._websocket||this.log.silly("IoService","socketSend() no _websocket");var t=JSON.stringify(e);this.sendBuffer.push(t),this.socketSendBuffer()},e.prototype.socketSendBuffer=function(){if(this.log.silly("IoService","socketSendBuffer() length:%s",this.sendBuffer.length),!this._websocket)throw new Error("socketSendBuffer(): no _websocket");if(this._websocket.readyState===WebSocket.OPEN)for(;this.sendBuffer.length;){var e=this.sendBuffer.shift();this.log.silly("IoService","socketSendBuffer() sending(%s)",e),this._websocket.send(e)}else this.log.warn("IoService","socketSendBuffer() readyState is not OPEN, send job delayed.")},e.prototype.socketUpdateState=function(){this.log.verbose("IoService","socketUpdateState() is %s",c[this._websocket.readyState]),this._websocket?this._readyState.next(this._websocket.readyState):this.log.error("IoService","socketUpdateState() no _websocket")},e.prototype.socketOnMessage=function(e){this.log.verbose("IoService","onMessage({data: %s})",e.data);var t=e.data,o={name:"raw",payload:t};try{var n=JSON.parse(t);o.name=n.name,o.payload=n.payload}catch(e){this.log.warn("IoService","onMessage parse message fail. save as RAW")}this.mtObserver.next(o)},e.prototype.socketOnError=function(e){this.log.silly("IoService","socketOnError(%s)",e)},e.prototype.socketOnClose=function(e){var t=this;this.log.verbose("IoService","socketOnClose({code:%s, reason:%s, returnValue:%s})",e.code,e.reason,e.returnValue),this.socketUpdateState(),this.autoReconnect?(this.state.on("pending"),setTimeout((function(){return r(t,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:return t.trys.push([0,2,,3]),[4,this.connectRxSocket()];case 1:return t.sent(),this.state.on(!0),[3,3];case 2:return e=t.sent(),this.log.warn("IoService","socketOnClose() autoReconnect() exception: %s",e),this.state.off(!0),[3,3];case 3:return[2]}}))}))}),1e3)):this.state.off(!0),this._websocket=null,e.wasClean||this.log.warn("IoService","socketOnClose() event.wasClean FALSE")},e}(),l=function(){function e(e,o){this.log=e,this.ngZone=o,this.message=new t.EventEmitter,this.scan=new t.EventEmitter,this.login=new t.EventEmitter,this.logout=new t.EventEmitter,this.error=new t.EventEmitter,this.heartbeat=new t.EventEmitter,this.timerSub=null,this.counter=0,this.timestamp=new Date,this.log.verbose("WechatyComponent","constructor() v%s",h)}return Object.defineProperty(e.prototype,"token",{get:function(){return this._token},set:function(e){this.log.verbose("WechatyComponent","set token(%s)",e);var t=(e||"").trim();if(this._token!==t){if(this._token=t,!this.ioService)return this.log.silly("WechatyComponent","set token() skip token init value"),void this.log.silly("WechatyComponent","set token() because ioService will do it inside ngOnInit()");this.log.silly("WechatyComponent","set token(%s) reloading ioService now...",t),this.ioService.token(this.token),this.ioService.restart()}else this.log.silly("WechatyComponent","set token(%s) not new",t)},enumerable:!1,configurable:!0}),e.prototype.ngOnInit=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:return this.log.verbose("WechatyComponent","ngOnInit() with token: "+this.token),this.ioService=new u,[4,this.ioService.init()];case 1:return e.sent(),this.ioService.event.subscribe(this.onIo.bind(this)),this.log.silly("WechatyComponent","ngOnInit() ioService.event.subscribe()-ed"),this.token?(this.ioService.token(this.token),[4,this.ioService.start()]):[3,3];case 2:e.sent(),e.label=3;case 3:return[2]}}))}))},e.prototype.ngOnDestroy=function(){this.log.verbose("WechatyComponent","ngOnDestroy()"),this.endTimer(),this.ioService&&this.ioService.stop()},e.prototype.onIo=function(e){switch(this.log.silly("WechatyComponent","onIo#%d(%s)",this.counter++,e.name),this.timestamp=new Date,e.name){case"scan":this.scan.emit(e.payload);break;case"login":this.login.emit(e.payload);break;case"logout":this.logout.emit(e.payload);break;case"message":this.message.emit(e.payload);break;case"error":this.error.emit(e.payload);break;case"ding":case"dong":case"raw":this.heartbeat.emit(e.name+"["+e.payload+"]");break;case"heartbeat":this.heartbeat.emit(e.payload);break;case"sys":this.log.silly("WechatyComponent","onIo(%s): %s",e.name,e.payload);break;default:this.log.warn("WechatyComponent","onIo() unknown event name: %s[%s]",e.name,e.payload)}},e.prototype.reset=function(e){this.log.verbose("WechatyComponent","reset(%s)",e);var t={name:"reset",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.shutdown=function(e){this.log.verbose("WechatyComponent","shutdown(%s)",e);var t={name:"shutdown",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.startSyncMessage=function(){this.log.verbose("WechatyComponent","startSyncMessage()");if(!this.ioService)throw new Error("no ioService");this.ioService.event.next({name:"botie",payload:{args:["message"],source:"return this.syncMessage(message)"}})},e.prototype.startTimer=function(){var e=this;this.log.verbose("WechatyComponent","startTimer()"),this.ender=new o.Subject,this.ngZone.runOutsideAngular((function(){e.timer=o.interval(3e3).pipe(n.tap((function(t){e.log.verbose("do"," %d",t)})),n.takeUntil(e.ender),n.share())})),this.timerSub=this.timer.subscribe((function(t){if(e.counter=t,!e.ioService)throw new Error("no ioService");e.ioService.rpcDing(e.counter)}))},e.prototype.endTimer=function(){this.log.verbose("WechatyComponent","endTimer()"),this.timerSub&&(this.timerSub.unsubscribe(),this.timerSub=null),this.ender&&this.ender.next(null)},e.prototype.logoff=function(e){this.log.silly("WechatyComponent","logoff(%s)",e);var t={name:"logout",payload:e};this.ioService.event.next(t)},Object.defineProperty(e.prototype,"readyState",{get:function(){return this.ioService.readyState},enumerable:!1,configurable:!0}),e}();l.decorators=[{type:t.Component,args:[{selector:"wechaty",template:"<ng-content></ng-content>"}]}],l.ctorParameters=function(){return[{type:s.Brolog},{type:t.NgZone}]},l.propDecorators={message:[{type:t.Output}],scan:[{type:t.Output}],login:[{type:t.Output}],logout:[{type:t.Output}],error:[{type:t.Output}],heartbeat:[{type:t.Output}],token:[{type:t.Input}]};var p=function(){};p.decorators=[{type:t.NgModule,args:[{id:"wechaty",declarations:[l],exports:[l]}]}],e.VERSION=h,e.WechatyComponent=l,e.WechatyModule=p,e.ɵa=l,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
***************************************************************************** */function r(e,t,o,n){return new(o||(o=Promise))((function(s,i){function r(e){try{c(n.next(e))}catch(e){i(e)}}function a(e){try{c(n.throw(e))}catch(e){i(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(r,a)}c((n=n.apply(e,t||[])).next())}))}function a(e,t){var o,n,s,i,r={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]};return i={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(i){return function(a){return function(i){if(o)throw new TypeError("Generator is already executing.");for(;r;)try{if(o=1,n&&(s=2&i[0]?n.return:i[0]?n.throw||((s=n.return)&&s.call(n),0):n.next)&&!(s=s.call(n,i[1])).done)return s;switch(n=0,s&&(i=[2&i[0],s.value]),i[0]){case 0:case 1:s=i;break;case 4:return r.label++,{value:i[1],done:!1};case 5:r.label++,n=i[1],i=[0];continue;case 7:i=r.ops.pop(),r.trys.pop();continue;default:if(!(s=r.trys,(s=s.length>0&&s[s.length-1])||6!==i[0]&&2!==i[0])){r=0;continue}if(3===i[0]&&(!s||i[1]>s[0]&&i[1]<s[3])){r.label=i[1];break}if(6===i[0]&&r.label<s[1]){r.label=s[1],s=i;break}if(s&&r.label<s[2]){r.label=s[2],r.ops.push(i);break}s[2]&&r.ops.pop(),r.trys.pop();continue}i=t.call(e,r)}catch(e){i=[6,e],n=0}finally{o=s=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,a])}}}Object.create;Object.create;var c,h="0.7.4";!function(e){e[e.CLOSED=WebSocket.CLOSED]="CLOSED",e[e.CLOSING=WebSocket.CLOSING]="CLOSING",e[e.CONNECTING=WebSocket.CONNECTING]="CONNECTING",e[e.OPEN=WebSocket.OPEN]="OPEN"}(c||(c={}));var u=function(){function e(){this.autoReconnect=!0,this.log=s.Brolog.instance(),this.CONNECT_TIMEOUT=1e4,this.ENDPOINT="wss://api.chatie.io/v0/websocket/token/",this.PROTOCOL="web|0.0.1",this.sendBuffer=[],this.log.verbose("IoService","constructor()")}return Object.defineProperty(e.prototype,"readyState",{get:function(){return this._readyState.asObservable()},enumerable:!1,configurable:!0}),e.prototype.init=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(n){switch(n.label){case 0:if(this.log.verbose("IoService","init()"),this.state)throw new Error("re-init");this.snapshot={readyState:c.CLOSED,event:null},this._readyState=new o.BehaviorSubject(c.CLOSED),this.state=new i.StateSwitch("IoService",this.log),this.state.setLog(this.log),n.label=1;case 1:return n.trys.push([1,4,,5]),[4,this.initStateDealer()];case 2:return n.sent(),[4,this.initRxSocket()];case 3:return n.sent(),[3,5];case 4:throw e=n.sent(),this.log.silly("IoService","init() exception: %s",e.message),e;case 5:return this.readyState.subscribe((function(e){t.log.silly("IoService","init() readyState.subscribe(%s)",c[e]),t.snapshot.readyState=e})),this.event.subscribe((function(e){t.log.silly("IoService","init() event.subscribe({name:%s})",e.name),t.snapshot.event=e})),[2]}}))}))},e.prototype.token=function(e){if(this.log.silly("IoService","token(%s)",e),!e)return this._token;this._token=e},e.prototype.start=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:if(this.log.verbose("IoService","start() with token:%s",this._token),!this._token)throw new Error("start() without token");if(this.state.on())throw new Error("state is already ON");if(this.state.pending())throw new Error("state is pending");this.state.on("pending"),this.autoReconnect=!0,t.label=1;case 1:return t.trys.push([1,3,,4]),[4,this.connectRxSocket()];case 2:return t.sent(),this.state.on(!0),[3,4];case 3:return e=t.sent(),this.log.warn("IoService","start() failed:%s",e.message),this.state.off(!0),[3,4];case 4:return[2]}}))}))},e.prototype.stop=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:if(this.log.verbose("IoService","stop()"),this.state.off()){if(this.log.warn("IoService","stop() state is already off"),this.state.pending())throw new Error("state pending() is true");return[2]}if(this.state.off("pending"),this.autoReconnect=!1,!this._websocket)throw new Error("no websocket");return[4,this.socketClose(1e3,"IoService.stop()")];case 1:return e.sent(),this.state.off(!0),[2]}}))}))},e.prototype.restart=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:this.log.verbose("IoService","restart()"),t.label=1;case 1:return t.trys.push([1,4,,5]),[4,this.stop()];case 2:return t.sent(),[4,this.start()];case 3:return t.sent(),[3,5];case 4:throw e=t.sent(),this.log.error("IoService","restart() error:%s",e.message),e;case 5:return[2]}}))}))},e.prototype.initStateDealer=function(){var e=this;this.log.verbose("IoService","initStateDealer()");this.readyState.pipe(n.filter((function(e){return e===c.OPEN}))).subscribe((function(t){return e.stateOnOpen()}))},e.prototype.initRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(s){if(this.log.verbose("IoService","initRxSocket()"),this.event)throw new Error("re-init is not permitted");return this.moObserver={next:this.socketSend.bind(this),error:this.socketClose.bind(this),complete:this.socketClose.bind(this)},e=new o.Observable((function(e){return t.log.verbose("IoService","initRxSocket() Observable.create()"),t.mtObserver=e,t.socketClose.bind(t)})),this.event=o.Subject.create(this.moObserver,e.pipe(n.share())),[2]}))}))},e.prototype.connectRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(o){if(this.log.verbose("IoService","connectRxSocket()"),this._websocket)throw new Error("already has a websocket");if(this.state.off())throw new Error("switch state is off");if(!this.state.pending())throw new Error("switch state is already ON");return this._websocket=new WebSocket(this.endPoint(),this.PROTOCOL),this.socketUpdateState(),e=new Promise((function(e,o){t.log.verbose("IoService","connectRxSocket() Promise()");var n=setTimeout((function(){t._websocket=null;var e=new Error("rxSocket connect timeout after "+Math.round(t.CONNECT_TIMEOUT/1e3));o(e)}),t.CONNECT_TIMEOUT);t._websocket.onopen=function(o){t.log.verbose("IoService","connectRxSocket() Promise() WebSocket.onOpen() resolve()"),t.socketUpdateState(),clearTimeout(n),e()}})),this._websocket.onmessage=this.socketOnMessage.bind(this),this._websocket.onerror=this.socketOnError.bind(this),this._websocket.onclose=this.socketOnClose.bind(this),[2,e]}))}))},e.prototype.endPoint=function(){var e=this.ENDPOINT+this._token;return this.log.verbose("IoService","endPoint() => %s",e),e},e.prototype.stateOnOpen=function(){this.log.verbose("IoService","stateOnOpen()"),this.socketSendBuffer(),this.rpcUpdate("from stateOnOpen()")},e.prototype.rpcDing=function(e){return r(this,void 0,void 0,(function(){var t;return a(this,(function(o){return this.log.verbose("IoService","ding(%s)",e),t={name:"ding",payload:e},this.event.next(t),[2]}))}))},e.prototype.rpcUpdate=function(e){return r(this,void 0,void 0,(function(){return a(this,(function(t){return this.event.next({name:"update",payload:e}),[2]}))}))},e.prototype.socketClose=function(e,t){return r(this,void 0,void 0,(function(){var o=this;return a(this,(function(s){switch(s.label){case 0:if(this.log.verbose("IoService","socketClose()"),!this._websocket)throw new Error("no websocket");return this._websocket.close(e,t),this.socketUpdateState(),[4,new Promise((function(e){o.readyState.pipe(n.filter((function(e){return e===c.CLOSED}))).subscribe(e)}))];case 1:return s.sent(),[2]}}))}))},e.prototype.socketSend=function(e){this.log.silly("IoService","socketSend({name:%s, payload:%s})",e.name,e.payload),this._websocket||this.log.silly("IoService","socketSend() no _websocket");var t=JSON.stringify(e);this.sendBuffer.push(t),this.socketSendBuffer()},e.prototype.socketSendBuffer=function(){if(this.log.silly("IoService","socketSendBuffer() length:%s",this.sendBuffer.length),!this._websocket)throw new Error("socketSendBuffer(): no _websocket");if(this._websocket.readyState===WebSocket.OPEN)for(;this.sendBuffer.length;){var e=this.sendBuffer.shift();this.log.silly("IoService","socketSendBuffer() sending(%s)",e),this._websocket.send(e)}else this.log.warn("IoService","socketSendBuffer() readyState is not OPEN, send job delayed.")},e.prototype.socketUpdateState=function(){var e;this.log.verbose("IoService","socketUpdateState() is %s",c[null===(e=this._websocket)||void 0===e?void 0:e.readyState]),this._websocket?this._readyState.next(this._websocket.readyState):this.log.error("IoService","socketUpdateState() no _websocket")},e.prototype.socketOnMessage=function(e){this.log.verbose("IoService","onMessage({data: %s})",e.data);var t=e.data,o={name:"raw",payload:t};try{var n=JSON.parse(t);o.name=n.name,o.payload=n.payload}catch(e){this.log.warn("IoService","onMessage parse message fail. save as RAW")}this.mtObserver.next(o)},e.prototype.socketOnError=function(e){this.log.silly("IoService","socketOnError(%s)",e)},e.prototype.socketOnClose=function(e){var t=this;this.log.verbose("IoService","socketOnClose({code:%s, reason:%s, returnValue:%s})",e.code,e.reason,e.returnValue),this.socketUpdateState(),this.autoReconnect?(this.state.on("pending"),setTimeout((function(){return r(t,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:return t.trys.push([0,2,,3]),[4,this.connectRxSocket()];case 1:return t.sent(),this.state.on(!0),[3,3];case 2:return e=t.sent(),this.log.warn("IoService","socketOnClose() autoReconnect() exception: %s",e),this.state.off(!0),[3,3];case 3:return[2]}}))}))}),1e3)):this.state.off(!0),this._websocket=null,e.wasClean||this.log.warn("IoService","socketOnClose() event.wasClean FALSE")},e}(),l=function(){function e(e,o){this.log=e,this.ngZone=o,this.message=new t.EventEmitter,this.scan=new t.EventEmitter,this.login=new t.EventEmitter,this.logout=new t.EventEmitter,this.error=new t.EventEmitter,this.heartbeat=new t.EventEmitter,this.timerSub=null,this.counter=0,this.timestamp=new Date,this.log.verbose("WechatyComponent","constructor() v%s",h)}return Object.defineProperty(e.prototype,"token",{get:function(){return this._token},set:function(e){this.log.verbose("WechatyComponent","set token(%s)",e);var t=(e||"").trim();if(this._token!==t){if(this._token=t,!this.ioService)return this.log.silly("WechatyComponent","set token() skip token init value"),void this.log.silly("WechatyComponent","set token() because ioService will do it inside ngOnInit()");this.log.silly("WechatyComponent","set token(%s) reloading ioService now...",t),this.ioService.token(this.token),this.ioService.restart()}else this.log.silly("WechatyComponent","set token(%s) not new",t)},enumerable:!1,configurable:!0}),e.prototype.ngOnInit=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:return this.log.verbose("WechatyComponent","ngOnInit() with token: "+this.token),this.ioService=new u,[4,this.ioService.init()];case 1:return e.sent(),this.ioService.event.subscribe(this.onIo.bind(this)),this.log.silly("WechatyComponent","ngOnInit() ioService.event.subscribe()-ed"),this.token?(this.ioService.token(this.token),[4,this.ioService.start()]):[3,3];case 2:e.sent(),e.label=3;case 3:return[2]}}))}))},e.prototype.ngOnDestroy=function(){this.log.verbose("WechatyComponent","ngOnDestroy()"),this.endTimer(),this.ioService&&this.ioService.stop()},e.prototype.onIo=function(e){switch(this.log.silly("WechatyComponent","onIo#%d(%s)",this.counter++,e.name),this.timestamp=new Date,e.name){case"scan":this.scan.emit(e.payload);break;case"login":this.login.emit(e.payload);break;case"logout":this.logout.emit(e.payload);break;case"message":this.message.emit(e.payload);break;case"error":this.error.emit(e.payload);break;case"ding":case"dong":case"raw":this.heartbeat.emit(e.name+"["+e.payload+"]");break;case"heartbeat":this.heartbeat.emit(e.payload);break;case"sys":this.log.silly("WechatyComponent","onIo(%s): %s",e.name,e.payload);break;default:this.log.warn("WechatyComponent","onIo() unknown event name: %s[%s]",e.name,e.payload)}},e.prototype.reset=function(e){this.log.verbose("WechatyComponent","reset(%s)",e);var t={name:"reset",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.shutdown=function(e){this.log.verbose("WechatyComponent","shutdown(%s)",e);var t={name:"shutdown",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.startSyncMessage=function(){this.log.verbose("WechatyComponent","startSyncMessage()");if(!this.ioService)throw new Error("no ioService");this.ioService.event.next({name:"botie",payload:{args:["message"],source:"return this.syncMessage(message)"}})},e.prototype.startTimer=function(){var e=this;this.log.verbose("WechatyComponent","startTimer()"),this.ender=new o.Subject,this.ngZone.runOutsideAngular((function(){e.timer=o.interval(3e3).pipe(n.tap((function(t){e.log.verbose("do"," %d",t)})),n.takeUntil(e.ender),n.share())})),this.timerSub=this.timer.subscribe((function(t){if(e.counter=t,!e.ioService)throw new Error("no ioService");e.ioService.rpcDing(e.counter)}))},e.prototype.endTimer=function(){this.log.verbose("WechatyComponent","endTimer()"),this.timerSub&&(this.timerSub.unsubscribe(),this.timerSub=null),this.ender&&this.ender.next(null)},e.prototype.logoff=function(e){this.log.silly("WechatyComponent","logoff(%s)",e);var t={name:"logout",payload:e};this.ioService.event.next(t)},Object.defineProperty(e.prototype,"readyState",{get:function(){return this.ioService.readyState},enumerable:!1,configurable:!0}),e}();l.decorators=[{type:t.Component,args:[{selector:"wechaty",template:"<ng-content></ng-content>"}]}],l.ctorParameters=function(){return[{type:s.Brolog},{type:t.NgZone}]},l.propDecorators={message:[{type:t.Output}],scan:[{type:t.Output}],login:[{type:t.Output}],logout:[{type:t.Output}],error:[{type:t.Output}],heartbeat:[{type:t.Output}],token:[{type:t.Input}]};var p=function(){};p.decorators=[{type:t.NgModule,args:[{id:"wechaty",declarations:[l],exports:[l]}]}],e.VERSION=h,e.WechatyComponent=l,e.WechatyModule=p,e.ɵa=l,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=chatie-angular.umd.min.js.map |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"reference","name":"WechatyComponent"},"ScanInfo":{"__symbolic":"interface"},"UserInfo":{"__symbolic":"interface"},"WechatyComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":47,"character":1},"arguments":[{"selector":"wechaty","template":"<ng-content></ng-content>"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"scan":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"login":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"logout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"heartbeat":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"token":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"brolog","name":"Brolog","line":108,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":109,"character":20}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"onIo":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"shutdown":[{"__symbolic":"method"}],"startSyncMessage":[{"__symbolic":"method"}],"startTimer":[{"__symbolic":"method"}],"endTimer":[{"__symbolic":"method"}],"logoff":[{"__symbolic":"method"}]}},"WechatyModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"id":"wechaty","declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"VERSION":"0.7.3"},"origins":{"ɵa":"./src/wechaty/wechaty.component","ScanInfo":"./src/wechaty/wechaty.component","UserInfo":"./src/wechaty/wechaty.component","WechatyComponent":"./src/wechaty/wechaty.component","WechatyModule":"./src/wechaty/wechaty.module","VERSION":"./src/version"},"importAs":"@chatie/angular"} | ||
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"reference","name":"WechatyComponent"},"ScanInfo":{"__symbolic":"interface"},"UserInfo":{"__symbolic":"interface"},"WechatyComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":47,"character":1},"arguments":[{"selector":"wechaty","template":"<ng-content></ng-content>"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"scan":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"login":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"logout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"heartbeat":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"token":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"brolog","name":"Brolog","line":108,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":109,"character":20}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"onIo":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"shutdown":[{"__symbolic":"method"}],"startSyncMessage":[{"__symbolic":"method"}],"startTimer":[{"__symbolic":"method"}],"endTimer":[{"__symbolic":"method"}],"logoff":[{"__symbolic":"method"}]}},"WechatyModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"id":"wechaty","declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"VERSION":"0.7.4"},"origins":{"ɵa":"./src/wechaty/wechaty.component","ScanInfo":"./src/wechaty/wechaty.component","UserInfo":"./src/wechaty/wechaty.component","WechatyComponent":"./src/wechaty/wechaty.component","WechatyModule":"./src/wechaty/wechaty.module","VERSION":"./src/version"},"importAs":"@chatie/angular"} |
/** | ||
* This file was auto generated from scripts/generate-version.sh | ||
*/ | ||
export const VERSION = '0.7.3'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIvaG9tZS9ydW5uZXIvd29yay9hbmd1bGFyL2FuZ3VsYXIvIiwic291cmNlcyI6WyJzcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBVyxPQUFPLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgZmlsZSB3YXMgYXV0byBnZW5lcmF0ZWQgZnJvbSBzY3JpcHRzL2dlbmVyYXRlLXZlcnNpb24uc2hcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT046IHN0cmluZyA9ICcwLjcuMydcbiJdfQ== | ||
export const VERSION = '0.7.4'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIvaG9tZS9ydW5uZXIvd29yay9hbmd1bGFyL2FuZ3VsYXIvIiwic291cmNlcyI6WyJzcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBVyxPQUFPLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgZmlsZSB3YXMgYXV0byBnZW5lcmF0ZWQgZnJvbSBzY3JpcHRzL2dlbmVyYXRlLXZlcnNpb24uc2hcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT046IHN0cmluZyA9ICcwLjcuNCdcbiJdfQ== |
@@ -287,3 +287,4 @@ import { __awaiter } from "tslib"; | ||
socketUpdateState() { | ||
this.log.verbose('IoService', 'socketUpdateState() is %s', ReadyState[this._websocket.readyState]); | ||
var _a; | ||
this.log.verbose('IoService', 'socketUpdateState() is %s', ReadyState[(_a = this._websocket) === null || _a === void 0 ? void 0 : _a.readyState]); | ||
if (!this._websocket) { | ||
@@ -356,2 +357,2 @@ this.log.error('IoService', 'socketUpdateState() no _websocket'); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"io.js","sourceRoot":"/home/runner/work/angular/angular/","sources":["src/wechaty/io.ts"],"names":[],"mappings":"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","sourcesContent":["import { VERSION }      from '../config'\n\nimport {\n  BehaviorSubject,\n  Observable,\n  Observer,\n  Subject,\n}                   from 'rxjs'\nimport {\n  filter,\n  share,\n}                   from 'rxjs/operators'\n\nimport { Brolog }       from 'brolog'\nimport { StateSwitch }  from 'state-switch'\n\nexport type WechatyEventName =\n    'scan'\n  | 'login' | 'logout'\n  | 'reset' | 'shutdown'\n  | 'ding'  | 'dong'\n  | 'message'\n  | 'heartbeat'\n  | 'update'\n  | 'error'\n\nexport type ServerEventName = 'sys'\n                            | 'botie'\n\nexport type IoEventName = 'raw' | WechatyEventName | ServerEventName\n\nexport interface IoEvent {\n  name: IoEventName,\n  payload: any,\n}\n\nexport enum ReadyState {\n  CLOSED      = WebSocket.CLOSED,\n  CLOSING     = WebSocket.CLOSING,\n  CONNECTING  = WebSocket.CONNECTING,\n  OPEN        = WebSocket.OPEN,\n}\n\nexport interface IoServiceSnapshot {\n  readyState: ReadyState\n  event:     IoEvent\n}\n\nexport class IoService {\n  // https://github.com/ReactiveX/rxjs/blob/master/src/observable/dom/WebSocketSubject.ts\n  public event: Subject<IoEvent>\n\n  private _readyState: BehaviorSubject<ReadyState>\n  public get readyState() {\n    return this._readyState.asObservable()\n  }\n\n  public snapshot: IoServiceSnapshot\n\n  private autoReconnect = true\n  private log = Brolog.instance()\n\n  private readonly CONNECT_TIMEOUT = 10 * 1000 // 10 seconds\n  private readonly ENDPOINT = 'wss://api.chatie.io/v0/websocket/token/'\n  private readonly PROTOCOL = 'web|0.0.1'\n\n  private _token: string // FIXME possible be `undefined`\n  private _websocket: WebSocket | null\n  private moObserver: Observer<IoEvent> // Mobile Originated. moObserver.next() means mobile is sending\n  private mtObserver: Observer<IoEvent> // Mobile Terminated. mtObserver.next() means mobile is receiving\n  private sendBuffer: string[] = []\n\n  private state: StateSwitch\n\n  constructor() {\n    this.log.verbose('IoService', 'constructor()')\n  }\n\n  public async init(): Promise<void> {\n    this.log.verbose('IoService', 'init()')\n\n    if (this.state) {\n      throw new Error('re-init')\n    }\n\n    this.snapshot = {\n      readyState: ReadyState.CLOSED,\n      event:     null,\n    }\n\n    this._readyState = new BehaviorSubject<ReadyState>(ReadyState.CLOSED)\n    this.state = new StateSwitch('IoService', this.log)\n    this.state.setLog(this.log)\n\n    try {\n      await this.initStateDealer()\n      await this.initRxSocket()\n    } catch (e) {\n      this.log.silly('IoService', 'init() exception: %s', e.message)\n      throw e\n    }\n\n    this.readyState.subscribe(s => {\n      this.log.silly('IoService', 'init() readyState.subscribe(%s)', ReadyState[s])\n      this.snapshot.readyState = s\n    })\n    // IMPORTANT: subscribe to event and make it HOT!\n    this.event.subscribe(s => {\n      this.log.silly('IoService', 'init() event.subscribe({name:%s})', s.name)\n      this.snapshot.event = s\n    })\n\n    return\n  }\n\n  public token(): string\n  public token(newToken: string): void\n\n  public token(newToken?: string): string | void {\n    this.log.silly('IoService', 'token(%s)', newToken)\n    if (newToken) {\n      this._token = newToken\n      return\n    }\n    return this._token\n  }\n\n  async start(): Promise<void> {\n    this.log.verbose('IoService', 'start() with token:%s', this._token)\n\n    if (!this._token) {\n      throw new Error('start() without token')\n    }\n\n    if (this.state.on()) {\n      throw new Error('state is already ON')\n    }\n    if (this.state.pending()) {\n      throw new Error('state is pending')\n    }\n\n    this.state.on('pending')\n\n    this.autoReconnect = true\n\n    try {\n      await this.connectRxSocket()\n      this.state.on(true)\n    } catch (e) {\n      this.log.warn('IoService', 'start() failed:%s', e.message)\n\n      this.state.off(true)\n    }\n  }\n\n  async stop(): Promise<void> {\n    this.log.verbose('IoService', 'stop()')\n\n    if (this.state.off()) {\n      this.log.warn('IoService', 'stop() state is already off')\n      if (this.state.pending()) {\n        throw new Error('state pending() is true')\n      }\n      return\n    }\n\n    this.state.off('pending')\n\n    this.autoReconnect = false\n\n    if (!this._websocket) {\n      throw new Error('no websocket')\n    }\n\n    await this.socketClose(1000, 'IoService.stop()')\n    this.state.off(true)\n\n    return\n  }\n\n  public async restart(): Promise<void> {\n    this.log.verbose('IoService', 'restart()')\n    try {\n      await this.stop()\n      await this.start()\n    } catch (e) {\n      this.log.error('IoService', 'restart() error:%s', e.message)\n      throw e\n    }\n    return\n  }\n\n  private initStateDealer() {\n    this.log.verbose('IoService', 'initStateDealer()')\n\n    const isReadyStateOpen = (s: ReadyState) => s === ReadyState.OPEN\n\n    this.readyState.pipe(\n      filter(isReadyStateOpen),\n    )\n      .subscribe(open => this.stateOnOpen())\n  }\n\n  /**\n   * Creates a subject from the specified observer and observable.\n   *  - https://github.com/Reactive-Extensions/RxJS/blob/master/doc/api/subjects/subject.md\n   * Create an Rx.Subject using Subject.create that allows onNext without subscription\n   *   A socket implementation (example, don't use)\n   *  - http://stackoverflow.com/a/34862286/1123955\n   */\n  private async initRxSocket(): Promise<void> {\n    this.log.verbose('IoService', 'initRxSocket()')\n\n    if (this.event) {\n      throw new Error('re-init is not permitted')\n    }\n\n    // 1. Mobile Originated. moObserver.next() means mobile is sending\n    this.moObserver = {\n      next:     this.socketSend.bind(this),\n      error:    this.socketClose.bind(this),\n      complete: this.socketClose.bind(this),\n    }\n\n    // 2. Mobile Terminated. mtObserver.next() means mobile is receiving\n    const observable = new Observable((observer: Observer<IoEvent>) => {\n      this.log.verbose('IoService', 'initRxSocket() Observable.create()')\n      this.mtObserver = observer\n\n      return this.socketClose.bind(this)\n    })\n\n    // 3. Subject for MO & MT Observers\n    this.event = Subject.create(this.moObserver, observable.pipe(share()))\n\n  }\n\n  private async connectRxSocket(): Promise<void> {\n    this.log.verbose('IoService', 'connectRxSocket()')\n\n    // FIXME: check & close the old one\n    if (this._websocket) {\n      throw new Error('already has a websocket')\n    }\n\n    // if (this.state.target() !== 'open'\n    //   || this.state.current() !== 'open'\n    //   || this.state.stable()\n    if (this.state.off()) {\n      throw new Error('switch state is off')\n    } else if (!this.state.pending()) {\n      throw new Error('switch state is already ON')\n    }\n\n    this._websocket = new WebSocket(this.endPoint(), this.PROTOCOL)\n    this.socketUpdateState()\n\n    const onOpenPromise = new Promise<void>((resolve, reject) => {\n      this.log.verbose('IoService', 'connectRxSocket() Promise()')\n\n      const id = setTimeout(() => {\n        this._websocket = null\n        const e = new Error('rxSocket connect timeout after '\n                            + Math.round(this.CONNECT_TIMEOUT / 1000),\n                          )\n        reject(e)\n      }, this.CONNECT_TIMEOUT) // timeout for connect websocket\n\n      this._websocket.onopen = (e) => {\n        this.log.verbose('IoService', 'connectRxSocket() Promise() WebSocket.onOpen() resolve()')\n        this.socketUpdateState()\n        clearTimeout(id)\n        resolve()\n      }\n    })\n\n    // Handle the payload\n    this._websocket.onmessage = this.socketOnMessage.bind(this)\n    // Deal the event\n    this._websocket.onerror   = this.socketOnError.bind(this)\n    this._websocket.onclose   = this.socketOnClose.bind(this)\n\n    return onOpenPromise\n  }\n\n  private endPoint(): string {\n    const url = this.ENDPOINT + this._token\n    this.log.verbose('IoService', 'endPoint() => %s', url)\n    return url\n  }\n\n  /******************************************************************\n   *\n   * State Event Listeners\n   *\n   */\n  private stateOnOpen() {\n    this.log.verbose('IoService', 'stateOnOpen()')\n\n    this.socketSendBuffer()\n    this.rpcUpdate('from stateOnOpen()')\n  }\n\n  /******************************************************************\n   *\n   * Io RPC Methods\n   *\n   */\n  async rpcDing(payload: any): Promise<any> {\n    this.log.verbose('IoService', 'ding(%s)', payload)\n\n    const e: IoEvent = {\n      name: 'ding',\n      payload,\n    }\n    this.event.next(e)\n    // TODO: get the return value\n  }\n\n  async rpcUpdate(payload: any): Promise<void> {\n    this.event.next({\n      name:     'update',\n      payload,\n    })\n  }\n\n  /******************************************************************\n   *\n   * Socket Actions\n   *\n   */\n  private async socketClose(code?: number, reason?: string): Promise<void> {\n    this.log.verbose('IoService', 'socketClose()')\n\n    if (!this._websocket) {\n      throw new Error('no websocket')\n    }\n\n    this._websocket.close(code, reason)\n    this.socketUpdateState()\n\n    const future = new Promise(resolve => {\n      this.readyState.pipe(\n        filter(s => s === ReadyState.CLOSED),\n      )\n      .subscribe(resolve)\n    })\n    await future\n\n    return\n  }\n\n  private socketSend(ioEvent: IoEvent) {\n    this.log.silly('IoService', 'socketSend({name:%s, payload:%s})', ioEvent.name, ioEvent.payload)\n\n    if (!this._websocket) {\n      this.log.silly('IoService', 'socketSend() no _websocket')\n    }\n\n    const strEvt = JSON.stringify(ioEvent)\n    this.sendBuffer.push(strEvt)\n\n    // XXX can move this to onOpen?\n    this.socketSendBuffer()\n  }\n\n  private socketSendBuffer(): void {\n    this.log.silly('IoService', 'socketSendBuffer() length:%s', this.sendBuffer.length)\n\n    if (!this._websocket) {\n      throw new Error('socketSendBuffer(): no _websocket')\n    }\n\n    if (this._websocket.readyState !== WebSocket.OPEN) {\n      this.log.warn('IoService', 'socketSendBuffer() readyState is not OPEN, send job delayed.')\n      return\n    }\n\n    while (this.sendBuffer.length) {\n      const buf = this.sendBuffer.shift()\n      this.log.silly('IoService', 'socketSendBuffer() sending(%s)', buf)\n      this._websocket.send(buf)\n    }\n  }\n\n  private socketUpdateState() {\n    this.log.verbose('IoService', 'socketUpdateState() is %s',\n                                  ReadyState[this._websocket.readyState],\n                    )\n\n    if (!this._websocket) {\n      this.log.error('IoService', 'socketUpdateState() no _websocket')\n      return\n    }\n\n    this._readyState.next(this._websocket.readyState)\n  }\n\n  /******************************************************************\n   *\n   * Socket Events Listener\n   *\n   */\n  private socketOnMessage(message: MessageEvent) {\n    this.log.verbose('IoService', 'onMessage({data: %s})', message.data)\n\n    const data = message.data // WebSocket data\n\n    const ioEvent: IoEvent = {\n      name:     'raw',\n      payload:  data,\n    } // this is default io event for unknown format message\n\n    try {\n      const obj = JSON.parse(data)\n      ioEvent.name = obj.name\n      ioEvent.payload = obj.payload\n    } catch (e) {\n      this.log.warn('IoService', 'onMessage parse message fail. save as RAW')\n    }\n\n    this.mtObserver.next(ioEvent)\n  }\n\n  private socketOnError(event: Event) {\n    this.log.silly('IoService', 'socketOnError(%s)', event)\n    // this._websocket = null\n  }\n\n  /**\n   * https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent\n   * code: 1006\tCLOSE_ABNORMAL\n   *  - Reserved. Used to indicate that a connection was closed abnormally\n   *    (that is, with no close frame being sent) when a status code is expected.\n   */\n  private socketOnClose(closeEvent: CloseEvent) {\n    this.log.verbose('IoService', 'socketOnClose({code:%s, reason:%s, returnValue:%s})',\n                                  closeEvent.code,\n                                  closeEvent.reason,\n                                  closeEvent.returnValue,\n                    )\n    this.socketUpdateState()\n    /**\n     * reconnect inside onClose\n     */\n    if (this.autoReconnect) {\n      this.state.on('pending')\n      setTimeout(async () => {\n        try {\n          await this.connectRxSocket()\n          this.state.on(true)\n        } catch (e) {\n          this.log.warn('IoService', 'socketOnClose() autoReconnect() exception: %s', e)\n          this.state.off(true)\n        }\n      }, 1000)\n    } else {\n      this.state.off(true)\n    }\n    this._websocket = null\n\n    if (!closeEvent.wasClean) {\n      this.log.warn('IoService', 'socketOnClose() event.wasClean FALSE')\n      // TODO emit error\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"io.js","sourceRoot":"/home/runner/work/angular/angular/","sources":["src/wechaty/io.ts"],"names":[],"mappings":"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","sourcesContent":["import { VERSION }      from '../config'\n\nimport {\n  BehaviorSubject,\n  Observable,\n  Observer,\n  Subject,\n}                   from 'rxjs'\nimport {\n  filter,\n  share,\n}                   from 'rxjs/operators'\n\nimport { Brolog }       from 'brolog'\nimport { StateSwitch }  from 'state-switch'\n\nexport type WechatyEventName =\n    'scan'\n  | 'login' | 'logout'\n  | 'reset' | 'shutdown'\n  | 'ding'  | 'dong'\n  | 'message'\n  | 'heartbeat'\n  | 'update'\n  | 'error'\n\nexport type ServerEventName = 'sys'\n                            | 'botie'\n\nexport type IoEventName = 'raw' | WechatyEventName | ServerEventName\n\nexport interface IoEvent {\n  name: IoEventName,\n  payload: any,\n}\n\nexport enum ReadyState {\n  CLOSED      = WebSocket.CLOSED,\n  CLOSING     = WebSocket.CLOSING,\n  CONNECTING  = WebSocket.CONNECTING,\n  OPEN        = WebSocket.OPEN,\n}\n\nexport interface IoServiceSnapshot {\n  readyState: ReadyState\n  event:     IoEvent\n}\n\nexport class IoService {\n  // https://github.com/ReactiveX/rxjs/blob/master/src/observable/dom/WebSocketSubject.ts\n  public event: Subject<IoEvent>\n\n  private _readyState: BehaviorSubject<ReadyState>\n  public get readyState() {\n    return this._readyState.asObservable()\n  }\n\n  public snapshot: IoServiceSnapshot\n\n  private autoReconnect = true\n  private log = Brolog.instance()\n\n  private readonly CONNECT_TIMEOUT = 10 * 1000 // 10 seconds\n  private readonly ENDPOINT = 'wss://api.chatie.io/v0/websocket/token/'\n  private readonly PROTOCOL = 'web|0.0.1'\n\n  private _token: string // FIXME possible be `undefined`\n  private _websocket: WebSocket | null\n  private moObserver: Observer<IoEvent> // Mobile Originated. moObserver.next() means mobile is sending\n  private mtObserver: Observer<IoEvent> // Mobile Terminated. mtObserver.next() means mobile is receiving\n  private sendBuffer: string[] = []\n\n  private state: StateSwitch\n\n  constructor() {\n    this.log.verbose('IoService', 'constructor()')\n  }\n\n  public async init(): Promise<void> {\n    this.log.verbose('IoService', 'init()')\n\n    if (this.state) {\n      throw new Error('re-init')\n    }\n\n    this.snapshot = {\n      readyState: ReadyState.CLOSED,\n      event:     null,\n    }\n\n    this._readyState = new BehaviorSubject<ReadyState>(ReadyState.CLOSED)\n    this.state = new StateSwitch('IoService', this.log)\n    this.state.setLog(this.log)\n\n    try {\n      await this.initStateDealer()\n      await this.initRxSocket()\n    } catch (e) {\n      this.log.silly('IoService', 'init() exception: %s', e.message)\n      throw e\n    }\n\n    this.readyState.subscribe(s => {\n      this.log.silly('IoService', 'init() readyState.subscribe(%s)', ReadyState[s])\n      this.snapshot.readyState = s\n    })\n    // IMPORTANT: subscribe to event and make it HOT!\n    this.event.subscribe(s => {\n      this.log.silly('IoService', 'init() event.subscribe({name:%s})', s.name)\n      this.snapshot.event = s\n    })\n\n    return\n  }\n\n  public token(): string\n  public token(newToken: string): void\n\n  public token(newToken?: string): string | void {\n    this.log.silly('IoService', 'token(%s)', newToken)\n    if (newToken) {\n      this._token = newToken\n      return\n    }\n    return this._token\n  }\n\n  async start(): Promise<void> {\n    this.log.verbose('IoService', 'start() with token:%s', this._token)\n\n    if (!this._token) {\n      throw new Error('start() without token')\n    }\n\n    if (this.state.on()) {\n      throw new Error('state is already ON')\n    }\n    if (this.state.pending()) {\n      throw new Error('state is pending')\n    }\n\n    this.state.on('pending')\n\n    this.autoReconnect = true\n\n    try {\n      await this.connectRxSocket()\n      this.state.on(true)\n    } catch (e) {\n      this.log.warn('IoService', 'start() failed:%s', e.message)\n\n      this.state.off(true)\n    }\n  }\n\n  async stop(): Promise<void> {\n    this.log.verbose('IoService', 'stop()')\n\n    if (this.state.off()) {\n      this.log.warn('IoService', 'stop() state is already off')\n      if (this.state.pending()) {\n        throw new Error('state pending() is true')\n      }\n      return\n    }\n\n    this.state.off('pending')\n\n    this.autoReconnect = false\n\n    if (!this._websocket) {\n      throw new Error('no websocket')\n    }\n\n    await this.socketClose(1000, 'IoService.stop()')\n    this.state.off(true)\n\n    return\n  }\n\n  public async restart(): Promise<void> {\n    this.log.verbose('IoService', 'restart()')\n    try {\n      await this.stop()\n      await this.start()\n    } catch (e) {\n      this.log.error('IoService', 'restart() error:%s', e.message)\n      throw e\n    }\n    return\n  }\n\n  private initStateDealer() {\n    this.log.verbose('IoService', 'initStateDealer()')\n\n    const isReadyStateOpen = (s: ReadyState) => s === ReadyState.OPEN\n\n    this.readyState.pipe(\n      filter(isReadyStateOpen),\n    )\n      .subscribe(open => this.stateOnOpen())\n  }\n\n  /**\n   * Creates a subject from the specified observer and observable.\n   *  - https://github.com/Reactive-Extensions/RxJS/blob/master/doc/api/subjects/subject.md\n   * Create an Rx.Subject using Subject.create that allows onNext without subscription\n   *   A socket implementation (example, don't use)\n   *  - http://stackoverflow.com/a/34862286/1123955\n   */\n  private async initRxSocket(): Promise<void> {\n    this.log.verbose('IoService', 'initRxSocket()')\n\n    if (this.event) {\n      throw new Error('re-init is not permitted')\n    }\n\n    // 1. Mobile Originated. moObserver.next() means mobile is sending\n    this.moObserver = {\n      next:     this.socketSend.bind(this),\n      error:    this.socketClose.bind(this),\n      complete: this.socketClose.bind(this),\n    }\n\n    // 2. Mobile Terminated. mtObserver.next() means mobile is receiving\n    const observable = new Observable((observer: Observer<IoEvent>) => {\n      this.log.verbose('IoService', 'initRxSocket() Observable.create()')\n      this.mtObserver = observer\n\n      return this.socketClose.bind(this)\n    })\n\n    // 3. Subject for MO & MT Observers\n    this.event = Subject.create(this.moObserver, observable.pipe(share()))\n\n  }\n\n  private async connectRxSocket(): Promise<void> {\n    this.log.verbose('IoService', 'connectRxSocket()')\n\n    // FIXME: check & close the old one\n    if (this._websocket) {\n      throw new Error('already has a websocket')\n    }\n\n    // if (this.state.target() !== 'open'\n    //   || this.state.current() !== 'open'\n    //   || this.state.stable()\n    if (this.state.off()) {\n      throw new Error('switch state is off')\n    } else if (!this.state.pending()) {\n      throw new Error('switch state is already ON')\n    }\n\n    this._websocket = new WebSocket(this.endPoint(), this.PROTOCOL)\n    this.socketUpdateState()\n\n    const onOpenPromise = new Promise<void>((resolve, reject) => {\n      this.log.verbose('IoService', 'connectRxSocket() Promise()')\n\n      const id = setTimeout(() => {\n        this._websocket = null\n        const e = new Error('rxSocket connect timeout after '\n                            + Math.round(this.CONNECT_TIMEOUT / 1000),\n                          )\n        reject(e)\n      }, this.CONNECT_TIMEOUT) // timeout for connect websocket\n\n      this._websocket.onopen = (e) => {\n        this.log.verbose('IoService', 'connectRxSocket() Promise() WebSocket.onOpen() resolve()')\n        this.socketUpdateState()\n        clearTimeout(id)\n        resolve()\n      }\n    })\n\n    // Handle the payload\n    this._websocket.onmessage = this.socketOnMessage.bind(this)\n    // Deal the event\n    this._websocket.onerror   = this.socketOnError.bind(this)\n    this._websocket.onclose   = this.socketOnClose.bind(this)\n\n    return onOpenPromise\n  }\n\n  private endPoint(): string {\n    const url = this.ENDPOINT + this._token\n    this.log.verbose('IoService', 'endPoint() => %s', url)\n    return url\n  }\n\n  /******************************************************************\n   *\n   * State Event Listeners\n   *\n   */\n  private stateOnOpen() {\n    this.log.verbose('IoService', 'stateOnOpen()')\n\n    this.socketSendBuffer()\n    this.rpcUpdate('from stateOnOpen()')\n  }\n\n  /******************************************************************\n   *\n   * Io RPC Methods\n   *\n   */\n  async rpcDing(payload: any): Promise<any> {\n    this.log.verbose('IoService', 'ding(%s)', payload)\n\n    const e: IoEvent = {\n      name: 'ding',\n      payload,\n    }\n    this.event.next(e)\n    // TODO: get the return value\n  }\n\n  async rpcUpdate(payload: any): Promise<void> {\n    this.event.next({\n      name:     'update',\n      payload,\n    })\n  }\n\n  /******************************************************************\n   *\n   * Socket Actions\n   *\n   */\n  private async socketClose(code?: number, reason?: string): Promise<void> {\n    this.log.verbose('IoService', 'socketClose()')\n\n    if (!this._websocket) {\n      throw new Error('no websocket')\n    }\n\n    this._websocket.close(code, reason)\n    this.socketUpdateState()\n\n    const future = new Promise(resolve => {\n      this.readyState.pipe(\n        filter(s => s === ReadyState.CLOSED),\n      )\n      .subscribe(resolve)\n    })\n    await future\n\n    return\n  }\n\n  private socketSend(ioEvent: IoEvent) {\n    this.log.silly('IoService', 'socketSend({name:%s, payload:%s})', ioEvent.name, ioEvent.payload)\n\n    if (!this._websocket) {\n      this.log.silly('IoService', 'socketSend() no _websocket')\n    }\n\n    const strEvt = JSON.stringify(ioEvent)\n    this.sendBuffer.push(strEvt)\n\n    // XXX can move this to onOpen?\n    this.socketSendBuffer()\n  }\n\n  private socketSendBuffer(): void {\n    this.log.silly('IoService', 'socketSendBuffer() length:%s', this.sendBuffer.length)\n\n    if (!this._websocket) {\n      throw new Error('socketSendBuffer(): no _websocket')\n    }\n\n    if (this._websocket.readyState !== WebSocket.OPEN) {\n      this.log.warn('IoService', 'socketSendBuffer() readyState is not OPEN, send job delayed.')\n      return\n    }\n\n    while (this.sendBuffer.length) {\n      const buf = this.sendBuffer.shift()\n      this.log.silly('IoService', 'socketSendBuffer() sending(%s)', buf)\n      this._websocket.send(buf)\n    }\n  }\n\n  private socketUpdateState() {\n    this.log.verbose('IoService', 'socketUpdateState() is %s',\n      ReadyState[this._websocket?.readyState],\n    )\n\n    if (!this._websocket) {\n      this.log.error('IoService', 'socketUpdateState() no _websocket')\n      return\n    }\n\n    this._readyState.next(this._websocket.readyState)\n  }\n\n  /******************************************************************\n   *\n   * Socket Events Listener\n   *\n   */\n  private socketOnMessage(message: MessageEvent) {\n    this.log.verbose('IoService', 'onMessage({data: %s})', message.data)\n\n    const data = message.data // WebSocket data\n\n    const ioEvent: IoEvent = {\n      name:     'raw',\n      payload:  data,\n    } // this is default io event for unknown format message\n\n    try {\n      const obj = JSON.parse(data)\n      ioEvent.name = obj.name\n      ioEvent.payload = obj.payload\n    } catch (e) {\n      this.log.warn('IoService', 'onMessage parse message fail. save as RAW')\n    }\n\n    this.mtObserver.next(ioEvent)\n  }\n\n  private socketOnError(event: Event) {\n    this.log.silly('IoService', 'socketOnError(%s)', event)\n    // this._websocket = null\n  }\n\n  /**\n   * https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent\n   * code: 1006\tCLOSE_ABNORMAL\n   *  - Reserved. Used to indicate that a connection was closed abnormally\n   *    (that is, with no close frame being sent) when a status code is expected.\n   */\n  private socketOnClose(closeEvent: CloseEvent) {\n    this.log.verbose('IoService', 'socketOnClose({code:%s, reason:%s, returnValue:%s})',\n                                  closeEvent.code,\n                                  closeEvent.reason,\n                                  closeEvent.returnValue,\n                    )\n    this.socketUpdateState()\n    /**\n     * reconnect inside onClose\n     */\n    if (this.autoReconnect) {\n      this.state.on('pending')\n      setTimeout(async () => {\n        try {\n          await this.connectRxSocket()\n          this.state.on(true)\n        } catch (e) {\n          this.log.warn('IoService', 'socketOnClose() autoReconnect() exception: %s', e)\n          this.state.off(true)\n        }\n      }, 1000)\n    } else {\n      this.state.off(true)\n    }\n    this._websocket = null\n\n    if (!closeEvent.wasClean) {\n      this.log.warn('IoService', 'socketOnClose() event.wasClean FALSE')\n      // TODO emit error\n    }\n  }\n}\n"]} |
@@ -11,3 +11,3 @@ import { __awaiter } from 'tslib'; | ||
*/ | ||
const VERSION = '0.7.3'; | ||
const VERSION = '0.7.4'; | ||
@@ -295,3 +295,4 @@ var ReadyState; | ||
socketUpdateState() { | ||
this.log.verbose('IoService', 'socketUpdateState() is %s', ReadyState[this._websocket.readyState]); | ||
var _a; | ||
this.log.verbose('IoService', 'socketUpdateState() is %s', ReadyState[(_a = this._websocket) === null || _a === void 0 ? void 0 : _a.readyState]); | ||
if (!this._websocket) { | ||
@@ -298,0 +299,0 @@ this.log.error('IoService', 'socketUpdateState() no _websocket'); |
{ | ||
"$schema": "./node_modules/ng-packagr/package.schema.json", | ||
"name": "@chatie/angular", | ||
"version": "0.7.3", | ||
"version": "0.7.4", | ||
"description": "Wechaty Component NgModule", | ||
@@ -6,0 +6,0 @@ "license": "Apache-2.0", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
324312
2378