|
@ -1,153 +1,153 @@ |
|
|
import Config from "@/common/js/config.js" |
|
|
import Config from "@/common/js/config.js" |
|
|
let prevSendTimeMs = 0; // 上一条消息发送时间
|
|
|
let prevSendTimeMs = 0; // 上一条消息发送时间
|
|
|
let socketMsgQueue = []; // socket消息队列
|
|
|
let socketMsgQueue = []; // socket消息队列
|
|
|
let sendHeartTimer = null; |
|
|
let sendHeartTimer = null; |
|
|
let heartbeatConst = 15000; // 心跳常量
|
|
|
let heartbeatConst = 15000; // 心跳常量
|
|
|
|
|
|
|
|
|
const actions = { |
|
|
const actions = { |
|
|
// 初始化socket
|
|
|
// 初始化socket
|
|
|
initSocket({ commit, dispatch, state }) { |
|
|
initSocket({ commit, dispatch, state }) { |
|
|
if (state.lockSocket) return; |
|
|
if (state.lockSocket) return; |
|
|
// const { token } = rootState.user;
|
|
|
// const { token } = rootState.user;
|
|
|
// if (!token) return;
|
|
|
// if (!token) return;
|
|
|
|
|
|
|
|
|
commit('setLockSocket', true); |
|
|
commit('setLockSocket', true); |
|
|
commit('setSocket', uni.connectSocket({ url: Config.msgUrl, complete: () => {} })); |
|
|
commit('setSocket', uni.connectSocket({ url: Config.msgUrl, complete: () => {} })); |
|
|
// dispatch('auth');
|
|
|
// dispatch('auth');
|
|
|
dispatch('onSocketOpen'); |
|
|
dispatch('onSocketOpen'); |
|
|
dispatch('onSocketMessage'); |
|
|
dispatch('onSocketMessage'); |
|
|
dispatch('onSocketClose'); |
|
|
dispatch('onSocketClose'); |
|
|
state.socket.onError(errMsg => console.error(errMsg)); |
|
|
state.socket.onError(errMsg => console.error(errMsg)); |
|
|
commit('setLockSocket', false); |
|
|
commit('setLockSocket', false); |
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
// websocket发送channelId进行认证
|
|
|
|
|
|
auth({ dispatch }) { |
|
|
|
|
|
const token = uni.$storage.getStorageSync('anyringToken'); |
|
|
|
|
|
const data = { type: 'Auth', data: { token } }; |
|
|
|
|
|
dispatch('sendSocketMessage', data); |
|
|
|
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
// 监听ws打开
|
|
|
// websocket发送channelId进行认证
|
|
|
onSocketOpen({ dispatch, commit, state }) { |
|
|
auth({ dispatch }) { |
|
|
state.socket.onOpen(res => { |
|
|
const token = uni.$storage.getStorageSync('anyringToken'); |
|
|
commit('setConnected', true); |
|
|
const data = { type: 'Auth', data: { token } }; |
|
|
prevSendTimeMs = Date.now(); |
|
|
dispatch('sendSocketMessage', data); |
|
|
dispatch('auth'); // 认证
|
|
|
}, |
|
|
// for (let i = 0; i < socketMsgQueue.length; i++) {
|
|
|
|
|
|
// dispatch('sendSocketMessage', socketMsgQueue[i]);
|
|
|
|
|
|
// }
|
|
|
|
|
|
// socketMsgQueue = [];
|
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
// 监听收到的ws消息
|
|
|
// 监听ws打开
|
|
|
onSocketMessage({ commit, dispatch, state }) { |
|
|
onSocketOpen({ dispatch, commit, state }) { |
|
|
state.socket.onMessage(res => { |
|
|
state.socket.onOpen(res => { |
|
|
if (!res || !res.data || !JSON.parse(res.data)) return; |
|
|
commit('setConnected', true); |
|
|
const resData = JSON.parse(res.data); |
|
|
prevSendTimeMs = Date.now(); |
|
|
const { messageSet, ackId } = resData; |
|
|
dispatch('auth'); // 认证
|
|
|
// 处理消息体对象
|
|
|
// for (let i = 0; i < socketMsgQueue.length; i++) {
|
|
|
messageSet.forEach(item => dispatch('handleMessagesData', item)); |
|
|
// dispatch('sendSocketMessage', socketMsgQueue[i]);
|
|
|
ackId && dispatch('sendSocketMessage', { type: 'Ack', data: { ackId } }); |
|
|
// }
|
|
|
}); |
|
|
// socketMsgQueue = [];
|
|
|
}, |
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
/** |
|
|
// 监听收到的ws消息
|
|
|
* 处理收到的消息内容 |
|
|
onSocketMessage({ commit, dispatch, state }) { |
|
|
* @param {object} item 单个消息体对象 |
|
|
state.socket.onMessage(res => { |
|
|
*/ |
|
|
if (!res || !res.data || !JSON.parse(res.data)) return; |
|
|
handleMessagesData({ dispatch, commit, state }, item) { |
|
|
const resData = JSON.parse(res.data); |
|
|
const data = JSON.parse(item.data); |
|
|
const { messageSet, ackId } = resData; |
|
|
switch (data.type) { |
|
|
// 处理消息体对象
|
|
|
case 'ChannelStatus': // 认证
|
|
|
messageSet.forEach(item => dispatch('handleMessagesData', item)); |
|
|
dispatch('handleAuthMessage', data); |
|
|
ackId && dispatch('sendSocketMessage', { type: 'Ack', data: { ackId } }); |
|
|
break; |
|
|
}); |
|
|
case 'Notification': // 系统通知
|
|
|
}, |
|
|
commit('setNotificationData', item); |
|
|
|
|
|
break; |
|
|
/** |
|
|
case 'Ring': // ring
|
|
|
* 处理收到的消息内容 |
|
|
commit('setRingData', item); |
|
|
* @param {object} item 单个消息体对象 |
|
|
break; |
|
|
*/ |
|
|
|
|
|
handleMessagesData({ dispatch, commit, state }, item) { |
|
|
|
|
|
const data = JSON.parse(item.data); |
|
|
|
|
|
switch (data.type) { |
|
|
|
|
|
case 'ChannelStatus': // 认证
|
|
|
|
|
|
dispatch('handleAuthMessage', data); |
|
|
|
|
|
break; |
|
|
|
|
|
case 'Notification': // 系统通知
|
|
|
|
|
|
commit('setNotificationData', item); |
|
|
|
|
|
break; |
|
|
|
|
|
case 'Ring': // ring
|
|
|
|
|
|
commit('setRingData', item); |
|
|
|
|
|
break; |
|
|
case 'Remind': // 小红点
|
|
|
case 'Remind': // 小红点
|
|
|
commit('setRemindData', item); |
|
|
commit('setRemindData', item); |
|
|
break; |
|
|
break; |
|
|
case 'Success': // 小红点
|
|
|
case 'SetMsgSuccess': // 成功
|
|
|
let arr = []; |
|
|
let arr = []; |
|
|
if (data.event === 'Notification') { |
|
|
if (data.event === 'Notification') { |
|
|
arr = state.notificationData; |
|
|
arr = state.notificationData; |
|
|
} else if (data.event === 'Ring') { |
|
|
} else if (data.event === 'Ring') { |
|
|
arr = state.ringData; |
|
|
arr = state.ringData; |
|
|
} else if (data.event === 'Remind') { |
|
|
} else if (data.event === 'Remind') { |
|
|
arr = state.remindData; |
|
|
arr = state.remindData; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
let del_index = -1; |
|
|
let del_index = -1; |
|
|
arr.forEach((item, index) => { |
|
|
arr.forEach((item, index) => { |
|
|
if (item.id === data.data.msgId) { |
|
|
if (item.id === data.data.msgId) { |
|
|
del_index = index; |
|
|
del_index = index; |
|
|
} |
|
|
} |
|
|
}) |
|
|
}) |
|
|
|
|
|
|
|
|
arr.splice(notification_index, 1); |
|
|
arr.splice(del_index, 1); |
|
|
|
|
|
|
|
|
if (data.event === 'Notification') { |
|
|
|
|
|
commit('uploadNotificationData', arr); |
|
|
|
|
|
} else if (data.event === 'Ring') { |
|
|
|
|
|
commit('uploadRingData', arr); |
|
|
|
|
|
} else if (data.event === 'Remind') { |
|
|
|
|
|
commit('uploadRemindData', arr); |
|
|
|
|
|
} |
|
|
|
|
|
break; |
|
|
|
|
|
default: |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
// 发送消息
|
|
|
if (data.event === 'Notification') { |
|
|
sendSocketMessage({ state }, data) { |
|
|
commit('uploadNotificationData', arr); |
|
|
if (state.connected) { |
|
|
} else if (data.event === 'Ring') { |
|
|
|
|
|
commit('uploadRingData', arr); |
|
|
|
|
|
} else if (data.event === 'Remind') { |
|
|
|
|
|
commit('uploadRemindData', arr); |
|
|
|
|
|
} |
|
|
|
|
|
break; |
|
|
|
|
|
default: |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
// 发送消息
|
|
|
|
|
|
sendSocketMessage({ state }, data) { |
|
|
|
|
|
if (state.connected) { |
|
|
prevSendTimeMs = Date.now(); |
|
|
prevSendTimeMs = Date.now(); |
|
|
const msg = JSON.stringify({ toDomain: 'Server', data: JSON.stringify(data) }); |
|
|
const msg = JSON.stringify({ toDomain: 'Server', data: JSON.stringify(data) }); |
|
|
state.socket.send({ data: msg }); |
|
|
state.socket.send({ data: msg }); |
|
|
} else { |
|
|
} else { |
|
|
socketMsgQueue.push(data); |
|
|
socketMsgQueue.push(data); |
|
|
} |
|
|
} |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
// 监听关闭事件
|
|
|
// 监听关闭事件
|
|
|
onSocketClose({ dispatch, commit, state }) { |
|
|
onSocketClose({ dispatch, commit, state }) { |
|
|
state.socket.onClose(() => { |
|
|
state.socket.onClose(() => { |
|
|
commit('setConnected', false); |
|
|
commit('setConnected', false); |
|
|
if (sendHeartTimer) clearInterval(sendHeartTimer); |
|
|
if (sendHeartTimer) clearInterval(sendHeartTimer); |
|
|
setTimeout(() => { |
|
|
setTimeout(() => { |
|
|
dispatch('initSocket'); |
|
|
dispatch('initSocket'); |
|
|
}, 300); |
|
|
}, 300); |
|
|
}); |
|
|
}); |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
* 处理auth认证返回的ChannelStatus消息 |
|
|
|
|
|
* @param {object} data 消息内容对象 |
|
|
|
|
|
*/ |
|
|
|
|
|
handleAuthMessage({ commit, dispatch }, data) { |
|
|
|
|
|
if (data.data.authed) { |
|
|
|
|
|
dispatch('sendHeart'); |
|
|
|
|
|
} else { |
|
|
|
|
|
uni.$u.toast(data.data.error.text); |
|
|
|
|
|
uni.$storage.removeStorageSync('anyringToken'); |
|
|
|
|
|
commit('setSocket', null); |
|
|
|
|
|
} |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
/** |
|
|
// 心跳检测
|
|
|
* 处理auth认证返回的ChannelStatus消息 |
|
|
sendHeart({ dispatch, state }) { |
|
|
* @param {object} data 消息内容对象 |
|
|
if (sendHeartTimer) clearInterval(sendHeartTimer); |
|
|
*/ |
|
|
sendHeartTimer = setInterval(() => { |
|
|
handleAuthMessage({ commit, dispatch }, data) { |
|
|
if (Date.now() - prevSendTimeMs >= heartbeatConst) { |
|
|
if (data.data.authed) { |
|
|
dispatch('sendSocketMessage', { type: 'Ping' }); |
|
|
dispatch('sendHeart'); |
|
|
} |
|
|
} else { |
|
|
}, 5000); |
|
|
uni.$u.toast(data.data.error.text); |
|
|
|
|
|
uni.$storage.removeStorageSync('anyringToken'); |
|
|
|
|
|
commit('setSocket', null); |
|
|
|
|
|
} |
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
// 心跳检测
|
|
|
|
|
|
sendHeart({ dispatch, state }) { |
|
|
|
|
|
if (sendHeartTimer) clearInterval(sendHeartTimer); |
|
|
|
|
|
sendHeartTimer = setInterval(() => { |
|
|
|
|
|
if (Date.now() - prevSendTimeMs >= heartbeatConst) { |
|
|
|
|
|
dispatch('sendSocketMessage', { type: 'Ping' }); |
|
|
|
|
|
} |
|
|
|
|
|
}, 5000); |
|
|
|
|
|
}, |
|
|
}, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|