jugglechat-websdk 1.6.7 → 1.6.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +9 -9
- package/package.json +1 -1
package/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*
|
|
2
|
-
* JuggleChat.js v1.6.
|
|
2
|
+
* JuggleChat.js v1.6.9
|
|
3
3
|
* (c) 2022-2024 JuggleChat
|
|
4
4
|
* Released under the MIT License.
|
|
5
5
|
*/const noop=()=>{},isObject=e=>"[object Object]"===Object.prototype.toString.call(e),isArray=e=>"[object Array]"===Object.prototype.toString.call(e),isFunction=e=>"[object Function]"===Object.prototype.toString.call(e),isString=e=>"[object String]"===Object.prototype.toString.call(e),isBoolean=e=>"[object Boolean]"===Object.prototype.toString.call(e),isUndefined=e=>"[object Undefined]"===Object.prototype.toString.call(e),isNull=e=>"[object Null]"===Object.prototype.toString.call(e),isNumber=e=>"[object Number]"===Object.prototype.toString.call(e),stringify=e=>JSON.stringify(e),parse=t=>{let n={};try{n=JSON.parse(t)}catch(s){n=t}return n},forEach=(e,t)=>{t=t||noop;isObject(e)&&(()=>{for(var n in e)t(e[n],n,e)})(),isArray(e)&&(()=>{for(var n=0,s=e.length;n<s;n++)t(e[n],n,e)})()},isEmpty=e=>{let t=!0;return isObject(e)&&forEach(e,()=>{t=!1}),(isString(e)||isArray(e))&&(t=0===e.length),isNumber(e)&&(t=-1===e),t},rename=(e,t)=>{var n=isObject(e);n&&(e=[e]),e=parse(stringify(e));var s=function(e,n,s){delete s[n],n=t[n],s[n]=e};return forEach(e,e=>{forEach(e,(e,n,o)=>{var i=(n in t);(i?s:noop)(e,n,o)})}),isObject?e[0]:e},extend=(e,t)=>(t=isArray(t)?t:[t],forEach(t,t=>{for(let n in t){let s=t[n];isUndefined(s)||(e[n]=s)}}),e),Defer=Promise,deferred=e=>new Defer(e),templateFormat=(e,t,n)=>{isArray(t)||(t=[t]);let s=[],o=t=>e.replace(n||/\\?\{([^}]+)\}/g,(e,n)=>"\\"===e.charAt(0)?e.slice(1):void 0===t[n]?"{"+n+"}":t[n]);for(let r=0,i=t.length;r<i;r++)s.push(o(t[r]));return s.join("")},isContain=(e,t)=>-1<e.indexOf(t),isEqual=(e,t)=>e===t,Cache$1=e=>{isObject(e)||(e={});let t=(t,n)=>{e[t]=n},n=t=>e[t],s=t=>{delete e[t]},o=()=>{let t=[];for(let n in e)t.push(n);return t},i=()=>{e={}};return{set:t,get:n,remove:s,getKeys:o,clear:i}},request=(e,t)=>deferred((n,s)=>{requestNormal(e,t,{success:n,fail:s})}),requestNormal=(e,t,n)=>{t=t||{},n=n||{success:noop,fail:noop,progress:noop};let s=new XMLHttpRequest,o=t.method||"GET";s.open(o,e,!0);let i=t.headers||{};forEach(i,(e,t)=>{s.setRequestHeader(t,e)});let r=t.body||{},a=()=>/^(200|202)$/.test(s.status),d=t.timeout;return d&&(s.timeout=d),s.onreadystatechange=function(){if(isEqual(s.readyState,4)){let{responseText:e}=s;e=e||"{}";let t=parse(e);if(a())n.success(t,s);else{let{status:e}=s,o={status:e,result:t};n.fail(o)}}},s.upload.onprogress=function(e){e.lengthComputable&&n.progress(e)},s.onerror=e=>{n.fail(e)},s.send(r),s},map=(e,t)=>e.map(t),filter=(e,t)=>e.filter(t),uniq=(e,t)=>{let n=[],s={};return e.forEach(e=>{let n=t(e);s[n.key]=n.value}),forEach(s,e=>{n.push(e)}),n},some=(e,t)=>e.some(t),toJSON=e=>JSON.stringify(e),toArray=e=>{let t=[];return forEach(e,(e,n)=>{t.push([n,e])}),t},isInclude=(e,t)=>-1<e.indexOf(t),clone$1=e=>JSON.parse(JSON.stringify(e));// 暂时支持 String
|
|
@@ -72,15 +72,15 @@ if(utils.isUndefined(N.name)){let e=UserCacher.get(O);N=utils.isEmpty(e)?{id:O}:
|
|
|
72
72
|
utils.isEmpty(l)||Storage.setPrefix(`${d}_${l}`);let m=common.getNaviStorageKey(d,l),u=Storage.get(m);return utils.isEmpty(u)?void utils.forEach(e,t=>{let l=t.replaceAll(/http:\/\/|https:\/\/|file:\/\//g,""),{http:u}=utils.getProtocol(t);l=`${u}//${l}/navigator/general`;let E={headers:{"x-appkey":d,"x-token":p}},g=utils.requestNormal(l,E,{success:function(e,t){if(!r){let{responseURL:i}=t,a=i.replace(/(\/navigator\/general)/g,"");r=!0;let{code:p,data:l={}}=e,{servers:u,user_id:E}=l,g={servers:u,userId:E,code:p,url:a};// 默认规则:导航和 CMP 的协议必须一致
|
|
73
73
|
utils.isEmpty(u)||(Storage.set(c,E),Storage.setPrefix(`${d}_${E}`),m=common.getNaviStorageKey(),Storage.set(m,g),o.info({tag:LOG_MODULE.NAV_REQEST,remote:g})),n(g),s()}},fail:function(t){a.push(t),utils.isEqual(a.length,e.length)&&n(t.result)}});i.push(g)}):(o.info({tag:LOG_MODULE.NAV_REQEST,local:u}),n(u))};var Network={detect,getNavis};function Consumer(){let e=[],t=!1,n=!1,s=(t,n)=>n?e.unshift(t):void e.push(t),o=s=>{// 如果正在执行,终止本次任务,执行任务结束后自动消费队列 ntf, 1 是首次,所以判断大于 1
|
|
74
74
|
if(n)return;n=!0,t=utils.isEqual(e.length,0);let i=e.shift(),r={item:i},a=()=>{n=!1,o(s)};t?n=!1:s(r,a)};return{consume:o,produce:s}}function MessageSyncer(e,t,n,{logger:s}){let o=Consumer(),i=i=>{function r(s,o){let{msg:i}=s,r=common.updateSyncTime({...i,io:n});if(r){let{msgIndex:n,ackIndex:s}=i,o={msgIndex:n,ackIndex:s};e(SIGNAL_CMD.PUBLISH_ACK,o),t.emit(SIGNAL_NAME.CMD_RECEIVED,i)}o()}function a(i,r){let{user:a,msg:d,name:p,$message:c}=i,l=Storage.get(STORAGE.SYNC_RECEIVED_MSG_TIME).time||1700927161470,m=Storage.get(STORAGE.SYNC_SENT_MSG_TIME).time||1700927161470;// 如果本地记录时间戳大于 ntf 中的接收时间,认为消息已被当前端接收过,不再执行拉取动作
|
|
75
|
-
if(l>=d.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncReceiveTime:l,msg:d}),r();let u={userId:a.id,syncTime:l,containsSendBox:!0,sendBoxSyncTime:m,topic:COMMAND_TOPICS.SYNC_MESSAGES};e(SIGNAL_CMD.QUERY,u,({isFinished:e,messages:a,code:p})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:u,msg:d,code:p,count:a.length}),!utils.isEqual(p,ErrorType.COMMAND_SUCCESS.code))return r();let l=[];utils.forEach(a,(e,t)=>{let{flags:n,sentTime:s,isSender:o}=e,i=common.formatter.toMsg(n);i.isStorage&&l.push(e)}),c.insertBatchMsgs({msgs:utils.clone(l)}).then(()=>{utils.forEach(a,(s,o)=>{let{sentTime:i,isSender:r}=s,d=common.updateSyncTime({sentTime:i,isSender:r,io:n});if(d){let n=e&&utils.isEqual(a.length-1,o);t.emit(SIGNAL_NAME.CMD_RECEIVED,[s,n])}});let s=!e;s&&o.produce(i,s),r()})})}
|
|
75
|
+
if(l>=d.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncReceiveTime:l,msg:d}),r();let u={userId:a.id,syncTime:l,containsSendBox:!0,sendBoxSyncTime:m,topic:COMMAND_TOPICS.SYNC_MESSAGES};e(SIGNAL_CMD.QUERY,u,({isFinished:e,messages:a,code:p})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:u,msg:d,code:p,count:a.length}),!utils.isEqual(p,ErrorType.COMMAND_SUCCESS.code))return r();let l=[];utils.forEach(a,(e,t)=>{let{flags:n,sentTime:s,isSender:o}=e,i=common.formatter.toMsg(n);i.isStorage&&l.push(e)}),c.insertBatchMsgs({msgs:utils.clone(l)}).then(()=>{utils.forEach(a,(s,o)=>{let{sentTime:i,isSender:r}=s,d=common.updateSyncTime({sentTime:i,isSender:r,io:n});if(d){let n=e&&utils.isEqual(a.length-1,o);t.emit(SIGNAL_NAME.CMD_RECEIVED,[s,n])}});let s=!e;s&&o.produce(i,s),r()})})}function d(n,i){let{user:r,name:a,time:d,$conversation:p}=n,c=Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0;if(c>d)return s.info({tag:LOG_MODULE.CONV_SYNC,syncTime:c,time:d}),i();let l={userId:r.id,syncTime:c,topic:COMMAND_TOPICS.SYNC_CONVERSATIONS,count:200};e(SIGNAL_CMD.QUERY,l,e=>{let{isFinished:r,conversations:a,code:d}=e;if(s.info({tag:LOG_MODULE.CONV_SYNC,data:l,code:d,count:a.length}),!utils.isEqual(d,ErrorType.COMMAND_SUCCESS.code))return t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATION_FINISHED,{}),i();let m=a.length,u=a[m-1]||{syncTime:0},{syncTime:E}=u;E>c&&(Storage.set(STORAGE.SYNC_CONVERSATION_TIME,{time:E}),n=utils.extend(n,{time:E})),a=utils.clone(a),p._batchInsertConversations({conversations:a,syncTime:E}).then(e=>{t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATIONS_PROGRESS,e);let s=!r;s?o.produce(n,s):t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATION_FINISHED,{}),i()})})}o.produce(i),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.CMD_RECEIVED)&&r(e,t),utils.isEqual(n,SIGNAL_NAME.S_SYNC_CONVERSATION_NTF)&&d(e,t),utils.isEqual(n,SIGNAL_NAME.S_NTF)&&a(e,t)})};return{exec:i}}let chatroomCacher=Cache();var chatroomCacher$1={set:(e,t)=>{let n=chatroomCacher.get(e),{msgs:s=[]}=t;200<=s.length&&(s.shift(0),t=utils.extend(t,{msgs:s})),n=utils.extend(n,t),chatroomCacher.set(e,n)},get:e=>{let t=chatroomCacher.get(e);return t},remove:e=>{chatroomCacher.remove(e)},getAll:()=>chatroomCacher.getAll()};function ChatroomSyncer(e,t,n,{logger:s}){let o=Consumer(),i=n=>{function i(e,t){s.info({tag:LOG_MODULE.MSG_SYNC,...e});let{msg:n}=e,o=chatroomCacher$1.get(n.targetId),{isJoined:i}=o;utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM)&&i&&a(e,t),utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM_DESTORY)&&i&&r(e,t)}function r(e,n){let{msg:s}=e,o=s.targetId;t.emit(SIGNAL_NAME.CMD_CHATROOM_DESTROY,{id:o}),n()}function a(n,o){let{msg:i}=n,r=i.targetId,a=d(r);if(a>=i.receiveTime&&0<i.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncTime:a,msg:i}),o();let c={syncTime:a,chatroomId:r,topic:COMMAND_TOPICS.SYNC_CHATROOM_MESSAGES};e(SIGNAL_CMD.QUERY,c,({messages:e,code:n})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:c,msg:i,code:n,count:e.length}),!utils.isEqual(n,ErrorType.COMMAND_SUCCESS.code))return o();let{msgs:a=[]}=chatroomCacher$1.get(r);utils.forEach(e,e=>{p(e.conversationId,e.sentTime);let{messageId:n}=e,s=utils.isInclude(a,n);s||(a.push(n),t.emit(SIGNAL_NAME.CMD_RECEIVED,[e]))}),chatroomCacher$1.set(r,{msgs:a}),o()})}function d(e){let t=chatroomCacher$1.get(e);return t.syncMsgTime||0}function p(e,t){let n=d(e);t>n&&chatroomCacher$1.set(e,{syncMsgTime:t})}o.produce(n),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.S_NTF)&&i(e,t)})};return{exec:i}}function ChatroomAttSyncer(e,t,n,{logger:s}){let o=Consumer(),i=n=>{function i(e,t){s.info({tag:LOG_MODULE.MSG_SYNC,...e});let{msg:n}=e,o=chatroomCacher$1.get(n.targetId),{isJoined:i}=o;utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM_ATTR)&&i&&r(e,t)}function r(n,o){let{msg:i}=n,r=i.targetId,p=a(r);if(p>=i.receiveTime&&0<i.receiveTime)return o();let c={syncTime:p,chatroomId:r,targetId:r,topic:COMMAND_TOPICS.SYNC_CHATROOM_ATTRS};e(SIGNAL_CMD.QUERY,c,e=>{let{code:n,attrs:r,chatroomId:a}=e;return s.info({tag:LOG_MODULE.MSG_SYNC,data:c,msg:i,code:n,count:r.length}),utils.isEqual(n,ErrorType.COMMAND_SUCCESS.code)?void(utils.forEach(r,e=>{d(a,e.updateTime)}),t.emit(SIGNAL_NAME.CMD_CHATROOM_ATTR_RECEIVED,{attrs:r,chatroomId:a}),o()):o()})}function a(e){let t=chatroomCacher$1.get(e);return t.syncAttTime||0}function d(e,t){let n=a(e);t>n&&chatroomCacher$1.set(e,{syncAttTime:t})}o.produce(n),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.S_NTF)&&i(e,t)})};return{exec:i}}function Timer(e={}){let t={timeout:60000};utils.extend(t,e);let{timeout:n}=t,s=0,o=utils.noop,i=e=>{o=e,s=setInterval(()=>{o()},n)},r=()=>{clearInterval(s)},a=()=>{r(),i(o)};return{resume:i,pause:r,reset:a}}function Counter(e={}){let t={timeout:10000};utils.extend(t,e);let{timeout:n}=t,s=0,o=e=>{s=setTimeout(()=>{e(t)},n)},i=()=>{clearTimeout(s)};return{start:o,clear:i}}let VERSION="1.6.9";/*
|
|
76
76
|
fileCompressLimit: 图片缩略图压缩限制,小于设置数值将不执行压缩,单位 KB
|
|
77
77
|
config = { appkey, nav, isSync, upload, uploadType, fileCompressLimit }
|
|
78
|
-
*/function IO(e){function t(){return
|
|
79
|
-
if(i)return
|
|
80
|
-
if(
|
|
81
|
-
utils.isEqual(e,CONVERATION_TYPE.CHATROOM)||common.updateSyncTime({...m,io:
|
|
82
|
-
if(
|
|
83
|
-
utils.isEqual(
|
|
78
|
+
*/function IO(e){function t(){l&&G.exec({msg:{type:NOTIFY_TYPE.MSG},name:SIGNAL_NAME.S_NTF,$message:e.$message,user:{id:R.id}})}function n(){return R}function s(){return e}function o(t){utils.extend(e,t)}function i(e,t){let n={topic:COMMAND_TOPICS.GET_USER_INFO,userId:e.id};k(SIGNAL_CMD.QUERY,n,e=>{t(e)})}let r=Emitter(),{appkey:a,navList:d,serverList:c=[],isSync:l=!0,reconnectCount:m=100,logger:p}=e;utils.isArray(d)||(d=["https://nav.juggleim.com"]);let u={},E={},g=Cache(),y=Decoder(g,E),T=Encoder(g),f=Timer({timeout:HEART_TIMEOUT}),C=Timer({timeout:SYNC_MESSAGE_TIME}),_=CONNECT_STATE.DISCONNECTED,S=[ErrorType.CONNECT_APPKEY_IS_REQUIRE.code,ErrorType.CONNECT_TOKEN_NOT_EXISTS.code,ErrorType.CONNECT_APPKEY_NOT_EXISTS.code,ErrorType.CONNECT_TOKEN_ILLEGAL.code,ErrorType.CONNECT_TOKEN_UNAUTHORIZED.code,ErrorType.CONNECT_TOKEN_EXPIRE.code,ErrorType.CONNECT_APP_BLOCKED.code,ErrorType.CONNECT_USER_BLOCKED.code,ErrorType.CONNECT_USER_KICKED.code,ErrorType.CONNECT_USER_LOGOUT.code],O=e=>{_=e.state,r.emit(SIGNAL_NAME.CONN_CHANGED,{...e})},I=()=>{f.pause(),C.pause()},N=!1,A=(e={})=>{let{code:t}=e;if(!N&&!utils.isInclude(S,t)&&!utils.isEqual(_,CONNECT_STATE.DISCONNECTED)){let e=n();return I(),D(e,({next:e})=>{e()})}if(!utils.isEqual(_,CONNECT_STATE.DISCONNECTED)){let t=n();O({state:CONNECT_STATE.DISCONNECTED,...e,user:t}),I()}},R={},M=e=>{utils.extend(R,e)},h=e=>{let t=common.getNaviStorageKey(a,e);Storage.remove(t)},v=({token:e,deviceId:t,_isReconnect:n=!1},s)=>{function o({servers:n,userId:o}){M({id:o,token:e,deviceId:t}),g.set(SIGNAL_NAME.S_CONNECT_ACK,s),Network.detect(n,(n,i)=>{// 如果嗅探失败,返回连接断开,同时清理已缓存的 CMP 地址
|
|
79
|
+
if(i)return h(o),D({token:e,userId:o,deviceId:t},s);n=n.replaceAll(/http:\/\/|https:\/\/|file:\/\/|wss:\/\/|ws:\/\//g,"");let{ws:r}=utils.getProtocol(),d=`${r}//${n}/im`;u=new WebSocket(d),p.info({tag:LOG_MODULE.WS_CONNECT}),u.onopen=function(){let n=PLATFORM.WEB;common.isDesktop()&&(n=PLATFORM.DESKTOP);let s=common.getClientSession();k(SIGNAL_CMD.CONNECT,{appkey:a,token:e,deviceId:t,platform:n,clientSession:s,sdkVerion:VERSION})},u.onclose=t=>{A({type:DISCONNECT_TYPE.CLOSE})},u.onerror=()=>{A({type:DISCONNECT_TYPE.ERROR})},u.onmessage=function({data:e}){let t=new FileReader;t.onload=function(){P(this.result)},t.readAsArrayBuffer(e)}})}g.set(STORAGE.CRYPTO_RANDOM,utils.getRandoms(8));let i=n?CONNECT_STATE.RECONNECTING:CONNECT_STATE.CONNECTING;return O({state:i}),utils.isEmpty(c)?Network.getNavis(d,{appkey:a,token:e,logger:p},e=>{let{code:t,servers:n,userId:i}=e;if(!utils.isEqual(t,ErrorType.COMMAND_SUCCESS.code)){let e=common.getError(t);return h(i),t||(e=ErrorType.IM_SERVER_CONNECT_ERROR),O({state:CONNECT_STATE.DISCONNECTED,code:e.code}),s({error:e})}o({servers:n,userId:i})}):o({servers:c})},D=({token:e,userId:t,deviceId:n},s)=>{p.info({tag:LOG_MODULE.CON_RECONNECT,userId:t,deviceId:n});let o=g.get(CONNECT_TOOL.RECONNECT_COUNT),i=o.count||1,a=i>m;if(a)return g.remove(CONNECT_TOOL.RECONNECT_COUNT),g.remove(CONNECT_TOOL.RECONNECT_FREQUENCY),O({state:CONNECT_STATE.DISCONNECTED,code:ErrorType.IM_SERVER_CONNECT_ERROR.code});let d=g.get(CONNECT_TOOL.RECONNECT_FREQUENCY),c=d.frequency||1,l=1e3*c;setTimeout(()=>{i+=1,g.set(CONNECT_TOOL.RECONNECT_COUNT,{count:i}),c*=2,g.set(CONNECT_TOOL.RECONNECT_FREQUENCY,{frequency:c}),v({token:e,userId:t,deviceId:n,_isReconnect:!0},e=>{let{error:t}=e;utils.isEqual(t.code,ErrorType.COMMAND_SUCCESS.code)&&r.emit(SIGNAL_NAME.CMD_CHATROOM_REJOIN,{}),s(e)})},l)},b=[],U=()=>{u&&u.close&&u.close(),f.pause(),C.pause(),b.length=0},x=()=>{N=!0,U()},k=(e,t,n)=>{n=n||utils.noop;let s=common.getNum();utils.isEqual(e,SIGNAL_CMD.CONNECT)&&(s=CONNECT_ACK_INDEX),utils.isEqual(e,SIGNAL_CMD.PING)&&(s=PONG_INDEX);let o=Counter({cmd:e}),i=T.encode(e,{callback:n,data:t,index:s,counter:o});u.send(i);let r=utils.clone(t);delete r.messages,p.info({tag:LOG_MODULE.WS_SEND,cmd:e,...r}),utils.isEqual(SIGNAL_CMD.PUBLISH_ACK,e)||o.start(({cmd:e})=>utils.isEqual(e,SIGNAL_CMD.PING)&&3>b.length?b.push({cmd:e}):void(n(ErrorType.COMMAND_FAILED),U()))},G=MessageSyncer(k,r,E,{logger:p}),L=ChatroomSyncer(k,r,E,{logger:p}),q=ChatroomAttSyncer(k,r,E,{logger:p}),P=n=>{let{cmd:s,result:o,name:d}=y.decode(n);p.info({tag:LOG_MODULE.WS_RECEIVE,cmd:s,code:o.code});let{index:c}=o,{callback:l,data:m,counter:u}=g.get(c);// 清空计时器,与 counter.start 对应
|
|
80
|
+
if(u&&(u.clear(),b.length=0),utils.isEqual(d,SIGNAL_NAME.S_CHATROOM_USER_NTF)){let{chatroomId:e,time:t,type:n}=o;r.emit(SIGNAL_NAME.CMD_CHATROOM_EVENT,{chatroomId:e,time:t,type:n})}if(utils.isEqual(d,SIGNAL_NAME.CMD_RECEIVED)&&(G.exec({msg:o,name:d,$message:e.$message,user:{id:R.id}}),C.reset()),utils.isEqual(d,SIGNAL_NAME.S_NTF)){let{type:t}=o,n={msg:o,name:d,$message:e.$message,user:{id:R.id}};utils.isEqual(t,NOTIFY_TYPE.MSG)&&G.exec(n),(utils.isEqual(t,NOTIFY_TYPE.CHATROOM)||utils.isEqual(t,NOTIFY_TYPE.CHATROOM_DESTORY))&&L.exec(n),utils.isEqual(t,NOTIFY_TYPE.CHATROOM_ATTR)&&q.exec(n),C.reset()}if(utils.isEqual(s,SIGNAL_CMD.PUBLISH_ACK)){utils.extend(m,o);let{conversationType:e}=m;// 单群聊和聊天室通知和拉取消息时间戳分开计算,只有发送单群聊消息更新发件箱
|
|
81
|
+
utils.isEqual(e,CONVERATION_TYPE.CHATROOM)||common.updateSyncTime({...m,io:E}),l(m)}if(utils.isEqual(s,SIGNAL_CMD.QUERY_ACK)&&l(o),utils.isEqual(s,SIGNAL_CMD.CONNECT_ACK)){N=!1;let n=g.get(SIGNAL_NAME.S_CONNECT_ACK)||utils.noop,{ack:{code:s,userId:r}}=o,d=CONNECT_STATE.CONNECT_FAILED,c=common.getError(s);if(utils.isEqual(s,ErrorType.CONNECT_SUCCESS.code))return d=CONNECT_STATE.CONNECTED,M({id:r}),Storage.setPrefix(`${a}_${r}`),g.remove(CONNECT_TOOL.RECONNECT_FREQUENCY),i({id:r},({user:s})=>{s=s||{};let o=s.nickname,i=s.userPortrait,l=utils.toObject(s.extFields);// 同步会话和同步消息顺序不能调整,保证先同步会话再同步消息,规避会话列表最后一条消息不是最新的
|
|
82
|
+
if(M({name:o,portrait:i,exts:l,updatedTime:s.updatedTime}),n({user:R,error:c,next:()=>{O({state:d,user:R})}}),e.isPC){let n=()=>{G.exec({time:Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0,name:SIGNAL_NAME.S_SYNC_CONVERSATION_NTF,user:{id:R.id},$conversation:e.$conversation}),t()},s=Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0;// PC 中先连接后打开数据库,优先将本地数据库中的同步时间更新至 LocalStorage 中,避免换 Token 不换用户 Id 重复同步会话
|
|
83
|
+
utils.isEqual(s,0)?e.$socket.openDB({appkey:a,userId:r,token:R.token}).then(()=>{n()}):n()}else t();f.resume(()=>{k(SIGNAL_CMD.PING,{}),p.info({tag:LOG_MODULE.HB_START})}),C.resume(()=>{G.exec({msg:{type:NOTIFY_TYPE.MSG},name:SIGNAL_NAME.S_NTF,$message:e.$message,user:{id:R.id}})})});O({state:d,user:R}),n({user:R,error:c})}if(utils.isEqual(s,SIGNAL_CMD.DISCONNECT)){let{code:e,extra:t}=o;A({code:e,extra:t,type:DISCONNECT_TYPE.SERVER})}utils.isEqual(d,SIGNAL_NAME.S_PONG)&&p.info({tag:LOG_MODULE.HB_STOP}),g.remove(c)},V=()=>utils.isEqual(_,CONNECT_STATE.CONNECTED),F=()=>utils.isEqual(_,CONNECT_STATE.DISCONNECTED);return utils.extend(E,{getConfig:s,setConfig:o,connect:v,disconnect:x,sendCommand:k,isConnected:V,isNeedConnect:F,getCurrentUser:n,getVersion:()=>VERSION,sync:e=>{e=utils.isArray(e)?e:[e];let t=s();utils.forEach(e,e=>{let n={...e,$message:t.$message},{msg:{type:s}}=e;utils.isEqual(s,NOTIFY_TYPE.CHATROOM)&&L.exec(n),utils.isEqual(s,NOTIFY_TYPE.CHATROOM_ATTR)&&q.exec(n)})},...r}),E}function Conversation$1(e,t){function n(t){let{conversationId:n,conversationType:o,conversationTitle:i,conversationPortrait:r,conversationExts:a,mentionInfo:d,messageId:p}=t,c={conversationId:n,conversationType:o,conversationTitle:i,conversationPortrait:r,conversationExts:a,latestMessage:t,unreadCount:0,updatedTime:0,undisturbType:t.undisturbType},l=s.getPer(t),m=l.mentions||{};if(d){let{members:n,type:s}=d,o=e.getCurrentUser(),i=utils.find(n,e=>utils.isEqual(o.id,e.id));//TODO 撤回 @ 消息需要删除
|
|
84
84
|
if(-1<i||utils.isEqual(s,MENTION_TYPE.ALL)){let{isMentioned:e=!0,senders:n=[],msgs:s=[]}=m;s.push({senderId:t.sender.id,messageId:t.messageId,sentTime:t.sentTime});let o=utils.find(n,e=>utils.isEqual(t.sender.id,e.id));utils.isEqual(o,-1)&&n.push(t.sender),m={isMentioned:e,senders:n,msgs:s,count:s.length}}utils.extend(c,{mentions:m})}if(t.isSender){let e=s.getPer(t);utils.extend(c,{conversationTitle:e.conversationTitle,conversationPortrait:e.conversationPortrait,conversationExts:e.conversationExts})}return c}/*
|
|
85
85
|
let params = {
|
|
86
86
|
type: UNDISTURB_TYPE.DISTURB,
|
|
@@ -98,7 +98,7 @@ if(utils.isEqual(o.name,MESSAGE_TYPE.CLEAR_MSG)){let{content:{cleanTime:e,conver
|
|
|
98
98
|
return void(utils.isInclude(r,a.tid)&&i({conversationId:t.conversationId,conversationType:t.conversationType}))}// 如果会话最后一条消息和被撤回消息不匹配,不更新会话列表
|
|
99
99
|
if(utils.isEqual(o.name,MESSAGE_TYPE.RECALL)){let{content:{messageId:e}}=o,t=s.getPer(o),{latestMessage:n}=t||{};if(n=n||{},!utils.isEqual(n.messageId,e))return;// 对外模拟 recallinfo 消息
|
|
100
100
|
o=utils.extend(o,{name:MESSAGE_TYPE.RECALL_INFO})}if(!utils.isInclude([MESSAGE_TYPE.READ_MSG,MESSAGE_TYPE.READ_GROUP_MSG],o.name)){if(utils.isEqual(o.name,MESSAGE_TYPE.CLEAR_UNREAD)){let{content:e}=o,{conversations:n}=e,i=s.read(n);return t.emit(EVENT.CONVERSATION_CLEARUNREAD,{conversations:n}),void(utils.isEmpty(i)||t.emit(EVENT.CONVERSATION_CHANGED,{conversations:i}))}if(utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_MARK_UNREAD)){let{content:{conversations:e}}=o,n=s.modify(e);return t.emit(EVENT.CONVERSATION_CHANGED,{conversations:n})}if(utils.isEqual(o.name,MESSAGE_TYPE.MODIFY)){let e=s.getPer(o),{latestMessage:t}=e||{};// 如果会话最后一条消息和被修改消息不匹配,不更新会话列表
|
|
101
|
-
if(t=t||{},!utils.isEqual(t.messageId,o.messageId))return;utils.extend(o,{name:t.name,isUpdated:!0})}i(o)}}),e.on(SIGNAL_NAME.CLIENT_CLEAR_MEMORY_CACHE,()=>{s.clear()});let o=(t={})=>utils.deferred((n,o)=>{let i=common.check(e,t,[]);if(!utils.isEmpty(i))return o(i);let{count:a=50,time:d=0,conversationType:r,order:p=CONVERSATION_ORDER.FORWARD}=t;p=utils.isEqual(p,CONVERSATION_ORDER.FORWARD)?CONVERSATION_ORDER.FORWARD:CONVERSATION_ORDER.BACKWARD;let c=e.getCurrentUser(),l={topic:COMMAND_TOPICS.CONVERSATIONS,time:0,count:a,order:p,userId:c.id,conversationType:r};utils.extend(l,t),e.sendCommand(SIGNAL_CMD.QUERY,l,e=>{let{code:t,msg:i}=e;if(!utils.isEqual(ErrorType.COMMAND_SUCCESS.code,t))return o({code:t,msg:i});if(!utils.isUndefined(r)){let t=utils.map(e.conversations,e=>{let{unreadCount:t}=e;return e.unreadCount=0>t?0:t,e});return n(utils.clone({conversations:t.reverse(),isFinished:e.isFinished}))}let{conversations:a}=e;s.setSynced(),s.add(a),n({conversations:utils.clone(a),isFinished:e.isFinished})})}),i=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.REMOVECONVERSATION);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser(),r={topic:COMMAND_TOPICS.REMOVE_CONVERSATION,conversations:t,userId:i.id};e.sendCommand(SIGNAL_CMD.QUERY,r,s=>{let o=utils.isArray(t)?t:[t],i=e.getConfig(),{timestamp:r,code:a}=s;if(o=utils.map(o,e=>(e.time=r,e)),utils.isEqual(ErrorType.COMMAND_SUCCESS.code,a)&&common.updateSyncTime({isSender:!0,sentTime:r,io:e}),!i.isPC){let t={name:MESSAGE_TYPE.COMMAND_REMOVE_CONVERS,content:{conversations:o}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,t)}n()})}),r=t=>utils.deferred((o,i)=>{let r=common.check(e,t,FUNC_PARAM_CHECKER.INSERTCONVERSATION);if(!utils.isEmpty(r))return i(r);let a=e.getCurrentUser(),d={topic:COMMAND_TOPICS.INSERT_CONVERSATION,conversation:t,userId:a.id};e.sendCommand(SIGNAL_CMD.QUERY,d,({code:r,msg:a,timestamp:d})=>{if(r)return i({code:r,msg:a});common.updateSyncTime({isSender:!0,sentTime:d,io:e});let p=n({...t,sentTime:Date.now()});s.update(p);let c=s.getPer(p);o({conversation:c})})}),a=t=>utils.deferred((n,o)=>{let i=common.check(e,t,FUNC_PARAM_CHECKER.GET_CONVERSATION);if(!utils.isEmpty(i))return o(i);let r=e.getCurrentUser(),a={topic:COMMAND_TOPICS.GET_CONVERSATION,conversation:t,userId:r.id};e.sendCommand(SIGNAL_CMD.QUERY,a,({code:e,msg:t,conversation:i})=>e?o({code:e,msg:t}):void(!utils.isEmpty(i)&&s.update(i),n({conversation:i})))}),d=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.MUTE_CONVERSATION);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser(),r={topic:COMMAND_TOPICS.MUTE_CONVERSATION,conversations:t,userId:i.id};e.sendCommand(SIGNAL_CMD.QUERY,r,({code:o,msg:i,timestamp:r})=>{if(!utils.isEqual(ErrorType.COMMAND_SUCCESS.code,o))return s({code:o,msg:i});common.updateSyncTime({isSender:!0,sentTime:r,io:e});let a=e.getConfig();if(!a.isPC){let n=utils.isArray(t)?t:[t],s={name:MESSAGE_TYPE.COMMAND_UNDISTURB,content:{conversations:n}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,s)}n()})}),p=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.SET_TOP_CONVERSATION);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser()
|
|
101
|
+
if(t=t||{},!utils.isEqual(t.messageId,o.messageId))return;utils.extend(o,{name:t.name,isUpdated:!0})}i(o)}}),e.on(SIGNAL_NAME.CLIENT_CLEAR_MEMORY_CACHE,()=>{s.clear()});let o=(t={})=>utils.deferred((n,o)=>{let i=common.check(e,t,[]);if(!utils.isEmpty(i))return o(i);let{count:a=50,time:d=0,conversationType:r,order:p=CONVERSATION_ORDER.FORWARD}=t;p=utils.isEqual(p,CONVERSATION_ORDER.FORWARD)?CONVERSATION_ORDER.FORWARD:CONVERSATION_ORDER.BACKWARD;let c=e.getCurrentUser(),l={topic:COMMAND_TOPICS.CONVERSATIONS,time:0,count:a,order:p,userId:c.id,conversationType:r};utils.extend(l,t),e.sendCommand(SIGNAL_CMD.QUERY,l,e=>{let{code:t,msg:i}=e;if(!utils.isEqual(ErrorType.COMMAND_SUCCESS.code,t))return o({code:t,msg:i});if(!utils.isUndefined(r)){let t=utils.map(e.conversations,e=>{let{unreadCount:t}=e;return e.unreadCount=0>t?0:t,e});return n(utils.clone({conversations:t.reverse(),isFinished:e.isFinished}))}let{conversations:a}=e;s.setSynced(),s.add(a),n({conversations:utils.clone(a),isFinished:e.isFinished})})}),i=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.REMOVECONVERSATION);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser(),r={topic:COMMAND_TOPICS.REMOVE_CONVERSATION,conversations:t,userId:i.id};e.sendCommand(SIGNAL_CMD.QUERY,r,s=>{let o=utils.isArray(t)?t:[t],i=e.getConfig(),{timestamp:r,code:a}=s;if(o=utils.map(o,e=>(e.time=r,e)),utils.isEqual(ErrorType.COMMAND_SUCCESS.code,a)&&common.updateSyncTime({isSender:!0,sentTime:r,io:e}),!i.isPC){let t={name:MESSAGE_TYPE.COMMAND_REMOVE_CONVERS,content:{conversations:o}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,t)}n()})}),r=t=>utils.deferred((o,i)=>{let r=common.check(e,t,FUNC_PARAM_CHECKER.INSERTCONVERSATION);if(!utils.isEmpty(r))return i(r);let a=e.getCurrentUser(),d={topic:COMMAND_TOPICS.INSERT_CONVERSATION,conversation:t,userId:a.id};e.sendCommand(SIGNAL_CMD.QUERY,d,({code:r,msg:a,timestamp:d})=>{if(r)return i({code:r,msg:a});common.updateSyncTime({isSender:!0,sentTime:d,io:e});let p=n({...t,sentTime:Date.now()});s.update(p);let c=s.getPer(p);o({conversation:c})})}),a=t=>utils.deferred((n,o)=>{let i=common.check(e,t,FUNC_PARAM_CHECKER.GET_CONVERSATION);if(!utils.isEmpty(i))return o(i);let r=e.getCurrentUser(),a={topic:COMMAND_TOPICS.GET_CONVERSATION,conversation:t,userId:r.id};e.sendCommand(SIGNAL_CMD.QUERY,a,({code:e,msg:t,conversation:i})=>e?o({code:e,msg:t}):void(!utils.isEmpty(i)&&s.update(i),n({conversation:i})))}),d=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.MUTE_CONVERSATION);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser(),r={topic:COMMAND_TOPICS.MUTE_CONVERSATION,conversations:t,userId:i.id};e.sendCommand(SIGNAL_CMD.QUERY,r,({code:o,msg:i,timestamp:r})=>{if(!utils.isEqual(ErrorType.COMMAND_SUCCESS.code,o))return s({code:o,msg:i});common.updateSyncTime({isSender:!0,sentTime:r,io:e});let a=e.getConfig();if(!a.isPC){let n=utils.isArray(t)?t:[t],s={name:MESSAGE_TYPE.COMMAND_UNDISTURB,content:{conversations:n}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,s)}n()})}),p=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.SET_TOP_CONVERSATION);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser();t=utils.isArray(t)?t:[t];let r={topic:COMMAND_TOPICS.TOP_CONVERSATION,conversations:t,userId:i.id};e.sendCommand(SIGNAL_CMD.QUERY,r,({code:o,msg:i,timestamp:r})=>{if(!utils.isEqual(ErrorType.COMMAND_SUCCESS.code,o))return s({code:o,msg:i});common.updateSyncTime({isSender:!0,sentTime:r,io:e});let a=e.getConfig();if(!a.isPC){let n={name:MESSAGE_TYPE.COMMAND_TOPCONVERS,content:{conversations:t}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,n)}n()})}),c=t=>utils.deferred((n,s)=>{let o=common.check(e,t,[]);if(!utils.isEmpty(o))return s(o);t=t||{};let{count:i=50,time:r=0}=t,a=e.getCurrentUser(),d={topic:COMMAND_TOPICS.QUERY_TOP_CONVERSATIONS,time:0,count:i,userId:a.id};utils.extend(d,t),e.sendCommand(SIGNAL_CMD.QUERY,d,e=>{n({conversations:e.conversations,isFinished:e.isFinished})})}),l=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.CLEARUNREADCOUNT);if(!utils.isEmpty(o))return s(o);let i=e.getCurrentUser(),r={topic:COMMAND_TOPICS.CLEAR_UNREAD};utils.extend(r,{conversations:t,userId:i.id}),e.sendCommand(SIGNAL_CMD.QUERY,r,s=>{let{timestamp:o,code:i}=s;utils.isEqual(ErrorType.COMMAND_SUCCESS.code,i)&&common.updateSyncTime({isSender:!0,sentTime:o,io:e});let r=e.getConfig();if(!r.isPC){let n={name:MESSAGE_TYPE.CLEAR_UNREAD,content:{conversations:t}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,n)}n()})}),m=(t={})=>utils.deferred((n,s)=>{let o=common.check(e,{},{});if(!utils.isEmpty(o))return s(o);let{conversationTypes:r=[],ignoreConversations:i}=t;if(r=utils.isArray(r)?r:[r],!utils.isEmpty(i)){let n=common.check(e,t,FUNC_PARAM_CHECKER.GET_TOTAL_UNREADCOUNT);if(!utils.isEmpty(n))return s(n)}let{id:a}=e.getCurrentUser(),d={topic:COMMAND_TOPICS.GET_UNREAD_TOTLAL_CONVERSATION,userId:a,conversationTypes:r,ignoreConversations:i};e.sendCommand(SIGNAL_CMD.QUERY,d,({count:e})=>{n({count:e})})}),u=()=>utils.deferred((t,n)=>{let o=common.check(e,{},{});if(!utils.isEmpty(o))return n(o);let{id:i}=e.getCurrentUser(),r={topic:COMMAND_TOPICS.CLEAR_UNREAD_TOTLAL_CONVERSATION,userId:i};e.sendCommand(SIGNAL_CMD.QUERY,r,()=>{let e=s.get();s.read(e),t()})}),E=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.SET_DRAFT);if(!utils.isEmpty(o))return s(o);let i=common.getDraftKey(t),{draft:r}=t;Storage.set(i,r),n()}),g=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.GET_DRAFT);if(!utils.isEmpty(o))return s(o);let i=common.getDraftKey(t),r=Storage.get(i);n(r)}),y=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.GET_DRAFT);if(!utils.isEmpty(o))return s(o);let i=common.getDraftKey(t),r=Storage.remove(i);n(r)}),T=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.SET_ALL_DISTURB);if(!utils.isEmpty(o))return s(o);let{code:i}=ErrorType.ILLEGAL_TYPE_PARAMS,r={timezone:"",times:[]},{type:a,timezone:d,times:p}=t,c=utils.isEqual(a,UNDISTURB_TYPE.DISTURB);if(c&&!utils.isString(d)){let e="timezone \u53C2\u6570\u4E0D\u5408\u6CD5\uFF0C\u8BF7\u68C0\u67E5\uFF0C\u683C\u5F0F\u793A\u4F8B\uFF1AAsia/Shanghai";return s({msg:"timezone \u53C2\u6570\u4E0D\u5408\u6CD5\uFF0C\u8BF7\u68C0\u67E5\uFF0C\u683C\u5F0F\u793A\u4F8B\uFF1AAsia/Shanghai",code:i})}if(c&&!utils.isArray(p)){let e="times \u53C2\u6570\u4E0D\u5408\u6CD5\uFF0C\u8BF7\u68C0\u67E5\uFF0C\u683C\u5F0F\u793A\u4F8B\uFF1A[{ start: '12:00', end: '13:00' }]";return s({msg:"times \u53C2\u6570\u4E0D\u5408\u6CD5\uFF0C\u8BF7\u68C0\u67E5\uFF0C\u683C\u5F0F\u793A\u4F8B\uFF1A[{ start: '12:00', end: '13:00' }]",code:i})}let l=!0,m=0;p=p||[];for(let e=0,t;e<p.length;e++){if(t=p[e],!utils.isObject(t)){l=!1,m=e;break}let{start:n,end:s}=t;if(!utils.isValidHMTime(n)||!utils.isValidHMTime(s)){l=!1,m=e;break}}if(!l){let e=`times 下标 ${m} 参数,时间格式不正确`;return s({msg:e,code:i})}r=utils.extend(r,t);let{id:u}=e.getCurrentUser(),E={topic:COMMAND_TOPICS.SET_ALL_DISTURB,userId:u,...r};e.sendCommand(SIGNAL_CMD.QUERY,E,()=>{n()})}),f=()=>utils.deferred((t,n)=>{let s=common.check(e,{},{});if(!utils.isEmpty(s))return n(s);let{id:o}=e.getCurrentUser(),i={topic:COMMAND_TOPICS.GET_ALL_DISTURB,userId:o};e.sendCommand(SIGNAL_CMD.QUERY,i,e=>{let{timezone:s,times:o,type:i,code:r}=e;return utils.isEqual(ErrorType.COMMAND_SUCCESS.code,r)?void t({timezone:s,times:o,type:i}):n({code:r,msg:""})})}),C=t=>utils.deferred((n,s)=>{let o=common.check(e,t,FUNC_PARAM_CHECKER.MARK_UNREAD);if(!utils.isEmpty(o))return s(o);t=utils.clone(t);let{id:i}=e.getCurrentUser(),r=utils.isArray(t)?t:[t],a={topic:COMMAND_TOPICS.MARK_CONVERSATION_UNREAD,userId:i,conversations:r};e.sendCommand(SIGNAL_CMD.QUERY,a,t=>{let{timestamp:o,code:i}=t;if(utils.isEqual(ErrorType.COMMAND_SUCCESS.code,i)){common.updateSyncTime({isSender:!0,sentTime:o,io:e});let t=e.getConfig();if(!t.isPC){let t={name:MESSAGE_TYPE.COMMAND_MARK_UNREAD,content:{conversations:r}};e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,t)}n()}else s({code:i})})});return{getConversations:o,removeConversation:i,insertConversation:r,getConversation:a,markUnread:C,disturbConversation:d,setTopConversation:p,getTopConversations:c,clearUnreadcount:l,getTotalUnreadcount:m,clearTotalUnreadcount:u,setDraft:E,getDraft:g,removeDraft:y,setAllDisturb:T,getAllDisturb:f}}function MessageCacher(){let e=Cache(),t=({conversationType:e,conversationId:t})=>`${e}_${t}`,n=(n,s)=>{let o=utils.isArray(s)?s:[s],i=t(n),r=e.get(i);utils.isEmpty(r)&&(r=[]),r=r.concat(o),r=utils.quickSort(r,(e,t)=>e.sentTime>t.sentTime),10<r.length&&(r.length=10),e.set(i,r)},s=n=>{let s=t(n),o=e.get(s);utils.isEmpty(o)&&(o=[]);let i=utils.filter(o,e=>utils.isEqual(e.sentTime,n.sentTime));return 0<i.length},o=()=>{e.clear()};return{add:n,isInclude:s,clear:o}}function Message$1(e,t,n){let s=MessageCacher();e.on(SIGNAL_NAME.CMD_RECEIVED,(o,i=!0)=>{n.info({tag:LOG_MODULE.MSG_RECEIVE,messageId:o.messageId});let r=utils.isEqual(o.conversationType,CONVERATION_TYPE.CHATROOM);if(r){let e=chatroomCacher$1.get(o.conversationId);return e.isJoined&&t.emit(EVENT.MESSAGE_RECEIVED,[o,!0])}if(utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_LOG_REPORT)){let{content:e,messageId:t}=o;return common.reportLogs({logger:n,params:{...e,messageId:t}})}if(utils.isEqual(o.name,MESSAGE_TYPE.MODIFY)){let{content:{content:e,messageId:t,sentTime:n}}=o,s=utils.decodeBase64(e),i=utils.parse(s);utils.extend(o,{content:i,messageId:t,sentTime:n})}// 收到非聊天室消息一定要更新会话列表
|
|
102
102
|
if(e.emit(SIGNAL_NAME.CMD_CONVERSATION_CHANGED,utils.clone(o)),utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_DELETE_MSGS)){let{content:{conversationId:e,conversationType:n,messages:s}}=o;return t.emit(EVENT.MESSAGE_REMOVED,{conversationId:e,conversationType:n,messages:s})}// 消息监听无需处理标记未读消息
|
|
103
103
|
if(!utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_MARK_UNREAD)&&!utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_CLEAR_TOTALUNREAD)&&!utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_ADD_CONVER)&&!utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_REMOVE_CONVERS)&&!utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_TOPCONVERS)&&!utils.isEqual(o.name,MESSAGE_TYPE.COMMAND_UNDISTURB)&&!utils.isEqual(o.name,MESSAGE_TYPE.CLEAR_UNREAD))//清理未读同步,只变更会话列表
|
|
104
104
|
// 消息监听无需处理免打扰
|