添加多房间支持

This commit is contained in:
xys20071111 2023-02-18 10:37:32 +08:00
parent be192c8585
commit c810083b74
No known key found for this signature in database
GPG Key ID: 0A8597188030E52C
7 changed files with 59 additions and 58 deletions

View File

@ -36,17 +36,14 @@ class APIMsgHandler extends EventEmitter {
const serverEventEmitter = new APIMsgHandler()
serverEventEmitter.on("SEND", (_socket: WebSocketClient, data: string) => {
sendDanmaku({
msg: data,
})
})
serverEventEmitter.on("ROOMID", (socket: WebSocket) => {
socket.send(JSON.stringify({
cmd: "ROOMID",
data: config.room_id,
}))
serverEventEmitter.on("SEND", (_socket: WebSocketClient, dataJson: string) => {
const data: {
msg: string
roomId: number
} = JSON.parse(dataJson)
sendDanmaku(data.roomId, {
msg: data.msg
})
})
server.on("connection", (client: WebSocketClient) => {

View File

@ -21,7 +21,7 @@ interface api_config {
}
interface ConfigStruct {
room_id: number
room_id: Array<number>
verify: Credential
danmakus: DanmakuTemplate
cold_down_time: number
@ -34,6 +34,6 @@ interface ConfigStruct {
}
const decoder = new TextDecoder('utf-8')
const config: ConfigStruct = JSON.parse(decoder.decode(Deno.readFileSync(`config/${Deno.args[0]}`)))
const config: ConfigStruct = JSON.parse(decoder.decode(Deno.readFileSync(Deno.args[0])))
export default config

View File

@ -12,13 +12,13 @@ let logFile = Deno.openSync(`./log/${getTimeString()}-${config.room_id}.log`, {
const thanksColdDownSet = new Set<string>()
export function receiveGift(data: any) {
export function receiveGift(roomId: number, data: any) {
if(thanksColdDownSet.has(data.uname)){
return
}
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} ${data.uname} 投喂了${data.super_gift_num}${data.giftName} 价值${data.price / 1000 * data.super_gift_num}\n`))
if (config.free_gift_action || data.super_gift_num > 0) {
sendDanmaku({
sendDanmaku(roomId, {
msg: FormatString(config.danmakus.gift, { name: data.uname, gift: data.giftName })
})
thanksColdDownSet.add(data.uname)
@ -26,46 +26,46 @@ export function receiveGift(data: any) {
}
}
export function onTotalGift(data: any) {
export function onTotalGift(roomId: number, data: any) {
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} ${data.uname}投喂了${data.total_num}${data.gift_name}\n`))
sendDanmaku({
sendDanmaku(roomId, {
msg: FormatString(config.danmakus.gift_total, { name: data.uname, gift: data.gift_name, count: data.total_num })
})
}
export function receiveDanmaku(data: any) {
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} ${data[2][1]}:${data[2][0]} ${data[1]}\n`))
export function receiveDanmaku(roomId:number, data: any) {
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} ${roomId} ${data[2][1]}:${data[2][0]} ${data[1]}\n`))
}
export function onLiveStart() {
export function onLiveStart(roomId: number) {
if(skipCount != 1){
skipCount ++
return
}
skipCount = 0
logFile.close()
sendDanmaku({ msg: config.danmakus.live_start })
sendDanmaku(roomId, { msg: config.danmakus.live_start })
logFile = Deno.openSync(`./log/${getTimeString()}-${config.room_id}.log`, {
create: true
})
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} 直播开始\n`))
}
export function onLiveEnd() {
export function onLiveEnd(roomId: number) {
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} 直播结束\n`))
sendDanmaku({ msg: config.danmakus.live_end })
sendDanmaku(roomId, { msg: config.danmakus.live_end })
}
export function onGraud(data: any) {
export function onGraud(roomId: number, data: any) {
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} ${data.username}:${data.uid} 购买了 ${data.gift_name}\n`))
sendDanmaku({
sendDanmaku(roomId, {
msg: FormatString(config.danmakus.guard, { type: data.gift_name, name: data.username })
})
}
export function onSuperChat(data: any) {
export function onSuperChat(roomId: number, data: any) {
logFile.writeSync(Encoding.UTF8.getBytes(`${getTimeString()} ${data.user_info.uname}发送了SC 价格${data.price}\n`))
sendDanmaku({
sendDanmaku(roomId, {
msg: FormatString(config.danmakus.sc, { name: data.user_info.uname })
})
}

View File

@ -127,9 +127,9 @@ export class DanmakuReceiver extends EventEmitter {
const packetData = resultRaw.slice(offset + 16, offset + length)
const data = JSON.parse(decoder.decode(packetData))
const cmd = data.cmd.split(":")[0]
this.emit(cmd, data.info || data.data)
this.emit(cmd, this.roomId, data.info || data.data)
apiServer.clients.forEach((client: WebSocketClient) => {
client.send(JSON.stringify({ cmd, data: data.info || data.data }))
client.send(JSON.stringify({ cmd, room: this.roomId, data: data.info || data.data }))
})
offset += length
}

View File

@ -2,5 +2,5 @@ import * as events from 'https://deno.land/x/events@v1.0.0/mod.ts'
const EventEmitter = events.default
export { EventEmitter }
export * as brotli from 'https://deno.land/x/brotli@v0.1.4/mod.ts'
export * as brotli from 'https://deno.land/x/brotli@0.1.7/mod.ts'
export { WebSocketServer, type WebSocketClient } from 'https://deno.land/x/websocket@v0.1.4/mod.ts'

View File

@ -4,31 +4,35 @@ import { onGraud, onLiveEnd, onLiveStart, onSuperChat, onTotalGift, receiveDanma
import { printLog } from './utils/mod.ts'
import { launchAllPlugins } from './Plugins.ts'
const danmakuReceiver = new DanmakuReceiver(config.room_id)
danmakuReceiver.on('connected', () => {
printLog('主程序', '连接成功')
})
const roomReceiverMap: Map<number, DanmakuReceiver> = new Map()
for(const room of config.room_id) {
const danmakuReceiver = new DanmakuReceiver(room)
danmakuReceiver.on('connected', () => {
printLog('主程序', '连接成功')
})
if (!config.disable_gift_action) {
danmakuReceiver.on('COMBO_SEND', onTotalGift)
danmakuReceiver.on('SEND_GIFT', receiveGift)
}
if (!config.disable_super_chat_action) {
danmakuReceiver.on('GUARD_BUY', onGraud)
}
if (!config.disable_super_chat_action) {
danmakuReceiver.on('SUPER_CHAT_MESSAGE', onSuperChat)
}
globalThis.onunload = () => {
printLog('主程序', '退出')
}
danmakuReceiver.on('closed', () => {
printLog('主程序', '掉线了')
if (!config.disable_gift_action) {
danmakuReceiver.on('COMBO_SEND', onTotalGift)
danmakuReceiver.on('SEND_GIFT', receiveGift)
}
if (!config.disable_super_chat_action) {
danmakuReceiver.on('GUARD_BUY', onGraud)
}
if (!config.disable_super_chat_action) {
danmakuReceiver.on('SUPER_CHAT_MESSAGE', onSuperChat)
}
globalThis.onunload = () => {
printLog('主程序', '退出')
}
danmakuReceiver.on('closed', () => {
printLog('主程序', '掉线了')
danmakuReceiver.connect()
})
danmakuReceiver.on('LIVE', onLiveStart)
danmakuReceiver.on('PREPARING', onLiveEnd)
danmakuReceiver.on('DANMU_MSG', receiveDanmaku)
danmakuReceiver.connect()
})
danmakuReceiver.on('LIVE', onLiveStart)
danmakuReceiver.on('PREPARING', onLiveEnd)
danmakuReceiver.on('DANMU_MSG', receiveDanmaku)
roomReceiverMap.set(room, danmakuReceiver)
}
launchAllPlugins()
danmakuReceiver.connect()

View File

@ -15,13 +15,13 @@ export interface DanmakuStruct {
csrf_token?: string
}
export function sendDanmaku(danmaku: DanmakuStruct) {
export function sendDanmaku(roomId: number, danmaku: DanmakuStruct) {
if (danmaku.msg.length > 19) {
sendDanmaku({
sendDanmaku(roomId, {
msg: danmaku.msg.slice(0, 15),
})
setTimeout(() => {
sendDanmaku({
sendDanmaku(roomId, {
msg: danmaku.msg.slice(15, danmaku.msg.length),
})
}, 2000)
@ -40,7 +40,7 @@ export function sendDanmaku(danmaku: DanmakuStruct) {
if (!danmaku.fontsize) {
danmaku.fontsize = 24
}
danmaku.roomid = config.room_id as number
danmaku.roomid = roomId
danmaku.csrf = danmaku.csrf_token = config.verify.csrf
const data = new FormData()
for (const k in danmaku) {