mirror of
https://github.com/LLOneBot/LLOneBot.git
synced 2024-11-22 01:56:33 +00:00
实现onebot协议中
This commit is contained in:
parent
881570c513
commit
9757fbd877
11
src/renderer.d.ts → src/global.d.ts
vendored
11
src/renderer.d.ts → src/global.d.ts
vendored
@ -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
|
||||
};
|
48
src/main.ts
48
src/main.ts
@ -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) => {
|
||||
|
@ -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: () => {
|
||||
|
@ -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)
|
||||
})
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user