实现onebot协议中

This commit is contained in:
linyuchen 2023-10-30 00:43:32 +08:00
parent 881570c513
commit 9757fbd877
4 changed files with 79 additions and 85 deletions

View File

@ -79,7 +79,16 @@ declare var LLAPI: {
getFriendsList(forced: boolean): Promise<User[]>
};
declare type PostDataSendMsg = {
action: "send_private_msg" | "send_group_msg" | "get_group_list",
params: {
user_id: string,
group_id: string,
message: SendMessage[];
}
}
declare var llonebot: {
listenSendMessage: (handle: (msg: any)=>void)=>void
listenSendMessage: (handle: (msg: PostDataSendMsg) => void) => void
startExpress: () => void
};

View File

@ -1,20 +1,10 @@
// 运行在 Electron 主进程 下的插件入口
const express = require("express")
const { ipcMain } = require('electron');
const { webContents } = require('electron')
const {ipcMain, webContents} = require('electron');
const CHANNEL_SEND_MSG = "llonebot_sendMsg"
type PostDataSendMsg = {
action: string,
params: {
user_id: string,
group_id: string,
message: SendMessage[];
}
}
function sendIPCCallSendQQMsg(postData: PostDataSendMsg) {
let contents = webContents.getAllWebContents();
for (const content of contents) {
@ -35,47 +25,12 @@ function startExpress(event: any){
app.use(express.json());
app.get('/', (req: any, res: any) => {
// original_send.call(window.webContents, "发送消息", {test: "test"})
// event.reply("发送消息", {test: "test"})
res.send('llonebot已启动');
})
// 处理POST请求的路由
app.post('/', (req: any, res: any) => {
let jsonData: PostDataSendMsg = req.body;
sendIPCCallSendQQMsg(jsonData);
// let json_data: {action: string, params: {
// user_id: string,
// group_id: string,
// message: SendMessage[];
// }} = req.body;
// let peer: Peer| null = null;
// if (json_data.action == "send_private_msg"){
// let friend = getFriend(json_data.params.user_id)
// if (friend) {
// peer = {
// chatType: "private",
// name: friend.nickName,
// uid: friend.uin
// }
// }
// }
// else if (json_data.action == "send_group_msg"){
// let group = getGroup(json_data.params.group_id)
// if (group){
// peer = {
// chatType: "group",
// name: group.name,
// uid: group.uid
// }
// }
// }
// if (peer) {
// original_send.call(window.webContents, "发送消息", peer, json_data.params.message)
// LLAPI.sendMessage(peer, json_data.params.message).then(res => console.log("消息发送成功:", res),
// err => console.log("消息发送失败", json_data, err))
// }
// console.log(req.body); // 输出POST请求的请求体数据
res.send('POST请求已收到');
});
app.listen(port, () => {
@ -84,7 +39,6 @@ function startExpress(event: any){
}
// 加载插件时触发
function onLoad(plugin: any) {
ipcMain.on("startExpress", (event: any, arg: any) => {

View File

@ -1,13 +1,13 @@
// Electron 主进程 与 渲染进程 交互的桥梁
const {contextBridge} = require("electron");
const {ipcRenderer} = require('electron');
// 在window对象下导出只读对象
contextBridge.exposeInMainWorld("llonebot", {
listenSendMessage: (handle: (msg: any)=>void)=>{
ipcRenderer.on("sendMsg", (event: any, args: any) => {
handle("收到ipc消息发送消息")
console.log("收到ipc消息发送消息", args); // 处理主进程发送的消息
listenSendMessage: (handle: (jsonData: PostDataSendMsg) => void) => {
ipcRenderer.on("sendMsg", (event: any, args: PostDataSendMsg) => {
handle(args)
})
},
startExpress: () => {

View File

@ -1,8 +1,9 @@
/// <reference path="./renderer.d.ts" />
/// <reference path="./global.d.ts" />
// import express from "express";
// const { ipcRenderer } = require('electron');
const host = "http://localhost:5000"
let groups: Group[] = []
@ -22,6 +23,44 @@ let uid_maps: Record<string, string> = {} // 一串加密的字符串 -> qq号
function onLoad() {
llonebot.startExpress();
llonebot.listenSendMessage((postData: PostDataSendMsg) => {
if (postData.action == "send_private_msg" || postData.action == "send_group_msg") {
let peer: Peer | null = null;
if (postData.action == "send_private_msg") {
let friend = getFriend(postData.params.user_id)
if (friend) {
peer = {
chatType: "private",
name: friend.nickName,
uid: friend.uin
}
}
}
else if (postData.action == "send_group_msg") {
let group = getGroup(postData.params.group_id)
if (group) {
peer = {
chatType: "group",
name: group.name,
uid: group.uid
}
}
}
if (peer) {
LLAPI.sendMessage(peer, postData.params.message).then(res => console.log("消息发送成功:", res),
err => console.log("消息发送失败", postData, err))
}
}
else if (postData.action == "get_group_list"){
let groupsData = groups.map(group => {
return {
group_id: group.uid,
group_name: group.name
}
})
}
});
window.LLAPI.getAccountInfo().then(accountInfo => {
self_qq = accountInfo.uid
})
@ -30,12 +69,7 @@ function onLoad(){
groups = groupsList
})
window.LLAPI.on("new-messages", (messages) => {
try{
llonebot.listenSendMessage(console.log);
console.log("ipc监听成功")
} catch (e){
console.log("ipc监听失败", e)
}
console.log("收到新消息", messages)
messages.forEach(message => {
let onebot_message_data: any = {
self: {
@ -53,17 +87,14 @@ function onLoad(){
if (element.raw.textElement?.atType == AtType.atUser) {
message_data["type"] = "at"
message_data["data"]["mention"] = element.raw.textElement.atUid
}
else if (element.raw.textElement){
} else if (element.raw.textElement) {
message_data["type"] = "text"
message_data["data"]["text"] = element.raw.textElement.content
}
else if (element.raw.picElement){
} else if (element.raw.picElement) {
message_data["type"] = "image"
message_data["data"]["file_id"] = element.raw.picElement.fileUuid
message_data["data"]["path"] = element.raw.picElement.sourcePath
}
else if (element.raw.replyElement){
} else if (element.raw.replyElement) {
message_data["type"] = "reply"
message_data["data"]["reply"] = element.raw.replyElement.sourceMsgIdInRecords
}
@ -75,8 +106,7 @@ function onLoad(){
onebot_message_data["group_id"] = message.peer.uid
// todo: 将加密的uid转成qq号
onebot_message_data["user_id"] = message.sender.uid
}
else if (message.peer.chatType == "private"){
} else if (message.peer.chatType == "private") {
onebot_message_data["user_id"] = message.peer.uid
}
@ -86,7 +116,8 @@ function onLoad(){
"Content-Type": "application/json"
},
body: JSON.stringify(onebot_message_data)
}).then(res => {}, err => {
}).then(res => {
}, err => {
console.log(err)
})
});