fix: ForwardController 中可能的 UnhandledException

This commit is contained in:
Clansty 2022-03-05 12:27:49 +08:00
parent d3e266d80f
commit 80473dde21
No known key found for this signature in database
GPG Key ID: 05F8479BA63A8E92
1 changed files with 50 additions and 44 deletions

View File

@ -2,12 +2,14 @@ import Telegram from '../client/Telegram';
import OicqClient from '../client/OicqClient';
import ForwardService from '../services/ForwardService';
import forwardPairs from '../providers/forwardPairs';
import { Friend, Group, GroupMessageEvent, PrivateMessageEvent } from 'oicq';
import { GroupMessageEvent, PrivateMessageEvent } from 'oicq';
import db from '../providers/db';
import { Api } from 'telegram';
import { getLogger } from 'log4js';
export default class ForwardController {
private readonly forwardService: ForwardService;
private readonly log = getLogger('ForwardController');
constructor(private readonly tgBot: Telegram,
private readonly tgUser: Telegram,
@ -19,13 +21,8 @@ export default class ForwardController {
}
private onQqMessage = async (event: PrivateMessageEvent | GroupMessageEvent) => {
let target: Friend | Group;
if (event.message_type === 'private') {
target = event.friend;
}
else {
target = event.group;
}
try {
const target = event.message_type === 'private' ? event.friend : event.group;
const pair = forwardPairs.find(target);
if (!pair) return;
const tgMessage = await this.forwardService.forwardFromQq(event, pair);
@ -45,9 +42,14 @@ export default class ForwardController {
},
});
}
}
catch (e) {
this.log.error('处理 QQ 消息时遇到问题', e);
}
};
private onTelegramMessage = async (message: Api.Message) => {
try{
const pair = forwardPairs.find(message.chat);
if (!pair) return;
const qqMessageSent = await this.forwardService.forwardFromTelegram(message, pair);
@ -68,5 +70,9 @@ export default class ForwardController {
},
});
}
}
catch (e) {
this.log.error('处理 Telegram 消息时遇到问题', e);
}
};
}