添加多房间支持
This commit is contained in:
parent
be192c8585
commit
c810083b74
@ -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) => {
|
||||
|
@ -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
|
||||
|
@ -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 })
|
||||
})
|
||||
}
|
||||
|
@ -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
|
||||
}
|
||||
|
@ -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'
|
||||
|
52
src/Main.ts
52
src/Main.ts
@ -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()
|
||||
|
@ -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) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user