From 8b6c967f2d6aad8364697ab4664f49e34f3ff86c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=B0=8F=E5=8F=B6?= <1936472877@qq.com> Date: Wed, 18 Dec 2024 12:32:48 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E5=8E=86=E5=8F=B2=E8=AE=B0=E5=BD=95?= =?UTF-8?q?=E7=BB=9F=E8=AE=A1=E6=9C=89=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- models/bind/index.js | 7 ++++--- models/db/history.js | 11 +++++++++++ models/task/index.js | 25 ++++++++++++++----------- 3 files changed, 29 insertions(+), 14 deletions(-) diff --git a/models/bind/index.js b/models/bind/index.js index da0dda8..26a9239 100644 --- a/models/bind/index.js +++ b/models/bind/index.js @@ -39,18 +39,19 @@ export async function getBindSteamIdsImg (bid, uid, gid, userBindAll = []) { const enablePushSteamIdList = enablePush ? await db.PushTableGetAllSteamIdBySteamIdAndGroupId(uid, gid, true) : [] const allSteamIdInfo = {} try { - const res = await api.ISteamUser.GetPlayerSummaries(userBindAll.map(i => i.steamId)).catch(() => []) + const res = await api.ISteamUser.GetPlayerSummaries(userBindAll.map(i => i.steamId)) res.forEach(i => { allSteamIdInfo[i.steamid] = i }) } catch { } let index = 1 for (const item of userBindAll) { - const avatar = Config.other.steamAvatar ? allSteamIdInfo[item.steamId].avatarfull : await utils.getUserAvatar(bid, uid, gid) + const i = allSteamIdInfo[item.steamId] || {} + const avatar = Config.other.steamAvatar ? i.avatarfull : await utils.getUserAvatar(bid, uid, gid) const info = { steamId: item.steamId, isBind: item.isBind, - name: allSteamIdInfo[item.steamId].personaname || await utils.getUserName(bid, uid, gid), + name: i.personaname || await utils.getUserName(bid, uid, gid), avatar: avatar || await utils.getUserAvatar(bid, uid, gid), index } diff --git a/models/db/history.js b/models/db/history.js index a8a10d1..3c02604 100644 --- a/models/db/history.js +++ b/models/db/history.js @@ -52,6 +52,17 @@ const HistoryTable = sequelize.define('history', { await HistoryTable.sync() +HistoryTable.findAll().then(res => { + if (res.length) { + // 在这之前统计的记录有误差 全部删除重新统计 + const time = 1734495420 + const data = res[0].dataValues + if (data.start < time && data.end < time) { + HistoryTable.truncate().catch(() => {}) + } + } +}).catch(() => {}) + /** * 添加一条记录 * @param {string} userId diff --git a/models/task/index.js b/models/task/index.js index 5f3da01..83c7696 100644 --- a/models/task/index.js +++ b/models/task/index.js @@ -34,13 +34,14 @@ export function startTimer () { if (lastPlay) { lastPlay = JSON.parse(lastPlay) } else { - lastPlay = { name: '', time: 0, appid: 0, state: 0 } + lastPlay = { name: '', appid: 0, state: 0, playTime: 0, onlineTime: 0 } } const state = { name: player.gameextrainfo, appid: player.gameid, - time: lastPlay.time, - state: player.personastate + state: player.personastate, + playTime: lastPlay.time || lastPlay.playTime, + onlineTime: lastPlay.time || lastPlay.onlineTime } // 如果这一次和上一次的状态不一样 if (lastPlay.appid != player.gameid || lastPlay.state != player.personastate) { @@ -68,20 +69,21 @@ export function startTimer () { state: [] } } - const time = now - lastPlay.time if (Config.push.enable && player.gameid && player.gameid != lastPlay.appid) { - state.time = now + const time = now - lastPlay.playTime + state.playTime = now userList[i.groupId][i.botId].start.push({ name: player.gameextrainfo, appid: `${nickname}(${player.personaname})`, - desc: lastPlay.time ? `距离上次 ${utils.formatDuration(time)}` : '', + desc: lastPlay.playTime ? `距离上次 ${utils.formatDuration(time)}` : '', header_image: iconUrl }) db.StatsTableUpdate(i.userId, i.groupId, i.botId, i.steamId, player.gameid, player.gameextrainfo, 'playTotal', 1).catch(e => logger.error('更新统计数据失败', e)) db.HistoryAdd(i.userId, i.groupId, i.botId, i.steamId, now, null, player.gameid, player.gameextrainfo).catch(e => logger.error('添加历史记录失败', e)) } if (Config.push.enable && lastPlay.name && lastPlay.name != player.gameextrainfo) { - state.time = now + const time = now - lastPlay.playTime + state.playTime = now userList[i.groupId][i.botId].end.push({ name: lastPlay.name, appid: `${nickname}(${player.personaname})`, @@ -89,15 +91,16 @@ export function startTimer () { header_image: utils.getHeaderImgUrlByAppid(lastPlay.appid) }) db.StatsTableUpdate(i.userId, i.groupId, i.botId, i.steamId, lastPlay.appid, lastPlay.name, 'playTime', time).catch(e => logger.error('更新统计数据失败', e)) - db.HistoryAdd(i.userId, i.groupId, i.botId, i.steamId, lastPlay.time, now, lastPlay.appid, lastPlay.name).catch(e => logger.error('添加历史记录失败', e)) + db.HistoryAdd(i.userId, i.groupId, i.botId, i.steamId, lastPlay.playTime, now, lastPlay.appid, lastPlay.name).catch(e => logger.error('添加历史记录失败', e)) } // 在线状态改变 if (Config.push.stateChange && player.personastate != lastPlay.state) { + const time = now - lastPlay.onlineTime if ([0, 1].includes(player.personastate)) { - state.time = now + state.onlineTime = now userList[i.groupId][i.botId].state.push({ name: `${nickname}(${player.personaname})`, - appid: lastPlay.time ? `距离上次 ${utils.formatDuration(time)}` : '', + appid: lastPlay.onlineTime ? `距离上次 ${utils.formatDuration(time)}` : '', desc: `已${utils.getPersonaState(player.personastate)}`, header_image: await utils.getUserAvatar(i.botId, i.userId, i.groupId) || (Config.other.steamAvatar ? i.avatarfull : ''), header_image_class: 'square', @@ -105,7 +108,7 @@ export function startTimer () { }) if (player.personastate === 0) { db.StatsTableUpdate(i.userId, i.groupId, i.botId, i.steamId, player.gameid, player.gameextrainfo, 'onlineTime', time).catch(e => logger.error('更新统计数据失败', e)) - db.HistoryAdd(i.userId, i.groupId, i.botId, i.steamId, lastPlay.time, now).catch(e => logger.error('添加历史记录失败', e)) + db.HistoryAdd(i.userId, i.groupId, i.botId, i.steamId, lastPlay.onlineTime, now).catch(e => logger.error('添加历史记录失败', e)) } else { db.StatsTableUpdate(i.userId, i.groupId, i.botId, i.steamId, player.gameid, player.gameextrainfo, 'onlineTotal', 1).catch(e => logger.error('更新统计数据失败', e)) db.HistoryAdd(i.userId, i.groupId, i.botId, i.steamId, now).catch(e => logger.error('添加历史记录失败', e))