Update bot to new discord API and add simple chatgpt module
This commit is contained in:
		| @@ -1,28 +1,32 @@ | ||||
| module.exports = class AudioQueue { | ||||
|     constructor(connection) { | ||||
|         this.connection = connection; | ||||
|         this.queue = []; | ||||
|         this.current = undefined; | ||||
|     } | ||||
|     playNext() { | ||||
|         if (this.queue.length == 0) { | ||||
|             this.current = undefined; | ||||
|             return; | ||||
|         } | ||||
|         this.current = this.connection.play(this.queue[0]); | ||||
|         this.current.on('speaking', (val) => {if (val == 0) this.handleStop(this.current)}); | ||||
|     } | ||||
|     handleStop(current) { | ||||
|         this.queue.shift(); | ||||
|         this.playNext(); | ||||
|     } | ||||
|     add(element) { | ||||
|         this.queue.push(element); | ||||
|         if (this.queue.length == 1) this.playNext(); | ||||
|     } | ||||
|     flush() { | ||||
|         this.current.setVolume(0); | ||||
|         this.queue=[]; | ||||
|         this.playNext(); | ||||
|     } | ||||
| const Voice = require("@discordjs/voice"); | ||||
|  | ||||
| module.exports = class AudioQueue { | ||||
|     constructor(connection, api) { | ||||
|         this.connection = connection; | ||||
|         this.api = api; | ||||
|         this.queue = []; | ||||
|         this.current = undefined; | ||||
|     } | ||||
|     playNext() { | ||||
|         if (this.queue.length == 0) { | ||||
|             this.current = undefined; | ||||
|             return; | ||||
|         } | ||||
|         this.current = this.api.play(this.queue[0]); | ||||
|         this.api.player.on(Voice.AudioPlayerStatus.Idle, this.handleStop.bind(this)); | ||||
|     } | ||||
|     handleStop(current) { | ||||
|         console.log(`Handling stop`); | ||||
|         this.queue.shift(); | ||||
|         this.playNext(); | ||||
|     } | ||||
|     add(element) { | ||||
|         this.queue.push(element); | ||||
|         if (this.queue.length == 1) this.playNext(); | ||||
|     } | ||||
|     flush() { | ||||
|         this.current.setVolume(0); | ||||
|         this.queue=[]; | ||||
|         this.playNext(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										62
									
								
								adapter.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								adapter.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| const { Snowflake, Client, Guild, VoiceBasedChannel, Events, Status, GatewayDispatchEvents } = require("discord.js"); | ||||
|  | ||||
| const adapters = new Map(); | ||||
| const trackedClients = new Set(); | ||||
| const trackedShards = new Map(); | ||||
|  | ||||
|  | ||||
| function trackClient(client) { | ||||
|     if (trackedClients.has(client)) return; | ||||
|     trackedClients.add(client); | ||||
|     client.ws.on(GatewayDispatchEvents.VoiceServerUpdate, (payload) => { | ||||
|         adapters.get(payload.guild_id)?.onVoiceServerUpdate(payload); | ||||
|     }); | ||||
|     client.ws.on(GatewayDispatchEvents.VoiceStateUpdate, (payload) => { | ||||
|         if (payload.guild_id && payload.session_id && payload.user_id === client.user?.id) { | ||||
|             adapters.get(payload.guild_id)?.onVoiceStateUpdate(payload); | ||||
|         } | ||||
|     }); | ||||
|     client.on(Events.ShardDisconnect, (_, shardId) => { | ||||
|         const guilds = trackedShards.get(shardId); | ||||
|         if (guilds) { | ||||
|             for (const guildID of guilds.values()) { | ||||
|                 adapters.get(guildID)?.destroy(); | ||||
|             } | ||||
|         } | ||||
|         trackedShards.delete(shardId); | ||||
|     }); | ||||
| } | ||||
|  | ||||
| function trackGuild(guild) { | ||||
|     let guilds = trackedShards.get(guild.shardId); | ||||
|     if (!guilds) { | ||||
|         guilds = new Set(); | ||||
|         trackedShards.set(guild.shardId, guilds); | ||||
|     } | ||||
|     guilds.add(guild.id); | ||||
| } | ||||
|  | ||||
|  | ||||
| module.exports = function (channel) { | ||||
|     return (methods) => { | ||||
|         adapters.set(channel.guild.id, methods); | ||||
|         trackClient(channel.client); | ||||
|         trackGuild(channel.guild); | ||||
|         return { | ||||
|             sendPayload(data) { | ||||
|                 console.log(channel.guild.shard.status); | ||||
|                 // if (channel.guild.shard.status === Status.READY) { | ||||
|                     console.log("Sending shard data"); | ||||
|                     channel.guild.shard.send(data); | ||||
|                     return true; | ||||
|                 // } | ||||
|                 console.log("Unable to send channel payload"); | ||||
|                 return false; | ||||
|             }, | ||||
|             destroy() { | ||||
|                 console.log("Destroying adapter"); | ||||
|                 return adapters.delete(channel.guild.id); | ||||
|             }, | ||||
|         }; | ||||
|     }; | ||||
| } | ||||
							
								
								
									
										60
									
								
								index.js
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								index.js
									
									
									
									
									
								
							| @@ -1,4 +1,6 @@ | ||||
| const Discord = require('discord.js'); | ||||
| const Voice = require("@discordjs/voice"); | ||||
| const adapterCreator = require("./adapter"); | ||||
| require('dotenv').config(); | ||||
| const fetch = require('node-fetch'); | ||||
| const fs = require('fs'); | ||||
| @@ -7,13 +9,28 @@ const sqlite3 = require('sqlite3'); | ||||
| const { open } = require('sqlite') | ||||
|  | ||||
| let joinedVoiceChannels = []; | ||||
| let modules = []; | ||||
| let commandHandlers = new Map(); | ||||
| let joinedVoiceChannelConnections = new Map(); | ||||
|  | ||||
| const bot = new Discord.Client(); | ||||
| let modules = []; | ||||
|  | ||||
| let commandHandlers = new Map(); | ||||
| const player = Voice.createAudioPlayer(); | ||||
|  | ||||
| const rest = new Discord.REST({ version: '10' }).setToken(process.env["TOKEN"]); | ||||
| const bot = new Discord.Client({ | ||||
|     intents: [ | ||||
|         Discord.GatewayIntentBits.GuildMembers, | ||||
|         Discord.GatewayIntentBits.GuildMessageReactions, | ||||
|         Discord.GatewayIntentBits.GuildMessages, | ||||
|         Discord.GatewayIntentBits.GuildPresences, | ||||
|         Discord.GatewayIntentBits.GuildVoiceStates, | ||||
|         Discord.GatewayIntentBits.Guilds, | ||||
|         Discord.GatewayIntentBits.MessageContent | ||||
|     ] | ||||
| }); | ||||
|  | ||||
| async function initDB() { | ||||
| console.log(__dirname); | ||||
|     console.log(__dirname); | ||||
|     api.db = await open({ | ||||
|         filename: process.env["DB_FILE"], | ||||
|         driver: sqlite3.Database | ||||
| @@ -21,9 +38,10 @@ console.log(__dirname); | ||||
| } | ||||
|  | ||||
| const api = { | ||||
|     player: player, | ||||
|     db: undefined, | ||||
|     queue: undefined, | ||||
|     strings: require('./strings/'+process.env.STRING_SET+'.json'), | ||||
|     strings: require('./strings/' + process.env.STRING_SET + '.json'), | ||||
|     ttsEngines: (() => { | ||||
|         let engines = {}; | ||||
|         console.log(`Registering TTS engines...`); | ||||
| @@ -39,6 +57,9 @@ const api = { | ||||
|     announcementVoice: process.env.ANNOUNCEMENT_VOICE, | ||||
|     announcementEngine: undefined, | ||||
|  | ||||
|     play: (file) => { | ||||
|         return player.play(Voice.createAudioResource(file)); | ||||
|     }, | ||||
|     respond: (message, text, voiceText) => { | ||||
|         let toSend = message.member.displayName + ", " + (voiceText ? voiceText : text); | ||||
|         if (message.member.voice.channel) { | ||||
| @@ -49,12 +70,14 @@ const api = { | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     getActiveVoiceChannel: () => joinedVoiceChannels[0], | ||||
|      | ||||
|     isInVoiceChannel: (channel) => { | ||||
|         return joinedVoiceChannels.includes(channel); | ||||
|     }, | ||||
|  | ||||
|     getConnectionForVoiceChannel: (channel) => { | ||||
|         return bot.voice.connections.find((conn) => conn.channel === channel); | ||||
|         return joinedVoiceChannelConnections.get(channel); | ||||
|     }, | ||||
|  | ||||
|     generateVoice: async (string, engine, voice, params) => { | ||||
| @@ -68,15 +91,24 @@ const api = { | ||||
|  | ||||
|     joinChannel: async (channel) => { | ||||
|         if (!api.isInVoiceChannel(channel)) { | ||||
|             const res = await channel.join(); | ||||
|  | ||||
|             const res = Voice.joinVoiceChannel({ | ||||
|                 channelId: channel.id, | ||||
|                 guildId: channel.guild.id, | ||||
|                 adapterCreator: adapterCreator(channel) | ||||
|             }); | ||||
|             res.subscribe(player); | ||||
|             joinedVoiceChannels.push(channel); | ||||
|             joinedVoiceChannelConnections.set(channel, res); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     leaveChannel: async (channel) => { | ||||
|         if (joinedVoiceChannels.includes(channel)) { | ||||
|             let con = joinedVoiceChannelConnections.get(channel); | ||||
|             joinedVoiceChannels = joinedVoiceChannels.filter((chan) => chan !== channel); | ||||
|             await channel.leave(); | ||||
|             con.disconnect(); | ||||
|             joinedVoiceChannelConnections.delete(channel); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| @@ -95,13 +127,14 @@ function registerModules() { | ||||
|     const moduleDirectories = fs.readdirSync('./modules'); | ||||
|     moduleDirectories.forEach((dir) => { | ||||
|         if (dir.startsWith('.')) return; | ||||
|         modules.push(require(`./modules/${dir}/index.js`)); | ||||
|         modules.push(require(`./modules/${dir}`)); | ||||
|         console.log(`Loading ./modules/${dir}/index.js`) | ||||
|     }) | ||||
|     modules.forEach((mod) => mod(bot, api)); | ||||
| } | ||||
|  | ||||
| function handleMessage(message) { | ||||
|     console.log(`I got message`); | ||||
|     if (message.content.startsWith(process.env.PREFIX)) { | ||||
|         const args = message.content.split(" "); | ||||
|         const command = args[0].substr(1, args[0].length); | ||||
| @@ -114,9 +147,12 @@ function handleMessage(message) { | ||||
|  | ||||
|  | ||||
| api.announcementEngine = api.ttsEngines[process.env.ANNOUNCEMENT_ENGINE]; | ||||
| (async () => { | ||||
|  | ||||
| async function start() { | ||||
|     await initDB(); | ||||
|     registerModules(); | ||||
| })() | ||||
| } | ||||
| bot.login(process.env.TOKEN); | ||||
| bot.on('message', handleMessage); | ||||
| bot.on('messageCreate', handleMessage); | ||||
|  | ||||
| start(); | ||||
| @@ -1,49 +1,49 @@ | ||||
| const printf=require('printf'); | ||||
| const fs = require('fs'); | ||||
| const path = require('path'); | ||||
|  | ||||
| module.exports = async (bot, api) => { | ||||
|     bot.on('message', async (message) => { | ||||
|         if (!message.content.startsWith(process.env.PREFIX)) { | ||||
|             if (message.channel.id == process.env.TTS_CHANNEL) { | ||||
|                 let chan=message.member.voice.channel; | ||||
|                 let userRow = await api.db.get('select * from TTSPreferences where user_id=?', message.author.id); | ||||
|                 if (!userRow) { | ||||
|                     await api.db.run('insert into TTSPreferences (user_id,engine,voice) values (?,?,?)', [message.author.id, api.announcementEngine.shortName, api.announcementVoice]); | ||||
|                     userRow = await api.db.get('select * from TTSPreferences where user_id=?', message.author.id); | ||||
|                 } | ||||
|                 if (api.ttsEngines[userRow.engine]) { | ||||
|                     api.speak(chan,message.content, api.ttsEngines[userRow.engine], userRow.voice) | ||||
|                 } else { | ||||
|  | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     }); | ||||
|     api.registerCommand('myvoice', async (args, message) => { | ||||
|         let userEngine, userVoice; | ||||
|         if (args.length > 3) { | ||||
|             return api.respond(message, printf(api.strings.TOO_MANY_ARGUMENTS)); | ||||
|         } | ||||
|         if (api.ttsEngines[args[1]]) { | ||||
|             userEngine = args[1]; | ||||
|             if (api.ttsEngines[userEngine].validateVoice(args[2].toLowerCase())) { | ||||
|                 userVoice = args[2].toLowerCase(); | ||||
|                 api.respond(message, printf(api.strings.USER_VOICE_CHANGED, userVoice, api.ttsEngines[userEngine].longName)); | ||||
|             } else { | ||||
|                 userVoice = api.ttsEngines[userEngine].getDefaultVoice(); | ||||
|                 api.respond(message, printf(api.strings.INVALID_VOICE, userVoice, api.ttsEngines[userEngine].longName)); | ||||
|             } | ||||
|             await api.db.run('update TTSPreferences set engine=?, voice=? where user_id=?', userEngine, userVoice, message.author.id); | ||||
|         } else { | ||||
|             api.respond(message, printf(api.strings.INVALID_ENGINE, args[1])); | ||||
|         } | ||||
|     }); | ||||
|     api.registerCommand('random', async (args, message) => { | ||||
|         const files = fs.readdirSync(process.env["VOICE_TMP_PATH"]); | ||||
|         const rnd = files[Math.floor(Math.random()*files.length)]; | ||||
|         console.log(rnd); | ||||
|         api.queue.add(__dirname + "/../../sysmsg.wav"); | ||||
|         api.queue.add(process.env["VOICE_TMP_PATH"] + "/" + rnd); | ||||
|     }); | ||||
| const printf=require('printf'); | ||||
| const fs = require('fs'); | ||||
| const path = require('path'); | ||||
|  | ||||
| module.exports = async (bot, api) => { | ||||
|     bot.on('messageCreate', async (message) => { | ||||
|         if (!message.content.startsWith(process.env.PREFIX)) { | ||||
|             if (message.channel.id == process.env.TTS_CHANNEL) { | ||||
|                 let chan=message.member.voice.channel; | ||||
|                 let userRow = await api.db.get('select * from TTSPreferences where user_id=?', message.author.id); | ||||
|                 if (!userRow) { | ||||
|                     await api.db.run('insert into TTSPreferences (user_id,engine,voice) values (?,?,?)', [message.author.id, api.announcementEngine.shortName, api.announcementVoice]); | ||||
|                     userRow = await api.db.get('select * from TTSPreferences where user_id=?', message.author.id); | ||||
|                 } | ||||
|                 if (api.ttsEngines[userRow.engine]) { | ||||
|                     api.speak(chan,message.content, api.ttsEngines[userRow.engine], userRow.voice) | ||||
|                 } else { | ||||
|  | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     }); | ||||
|     api.registerCommand('myvoice', async (args, message) => { | ||||
|         let userEngine, userVoice; | ||||
|         if (args.length > 3) { | ||||
|             return api.respond(message, printf(api.strings.TOO_MANY_ARGUMENTS)); | ||||
|         } | ||||
|         if (api.ttsEngines[args[1]]) { | ||||
|             userEngine = args[1]; | ||||
|             if (api.ttsEngines[userEngine].validateVoice(args[2].toLowerCase())) { | ||||
|                 userVoice = args[2].toLowerCase(); | ||||
|                 api.respond(message, printf(api.strings.USER_VOICE_CHANGED, userVoice, api.ttsEngines[userEngine].longName)); | ||||
|             } else { | ||||
|                 userVoice = api.ttsEngines[userEngine].getDefaultVoice(); | ||||
|                 api.respond(message, printf(api.strings.INVALID_VOICE, userVoice, api.ttsEngines[userEngine].longName)); | ||||
|             } | ||||
|             await api.db.run('update TTSPreferences set engine=?, voice=? where user_id=?', userEngine, userVoice, message.author.id); | ||||
|         } else { | ||||
|             api.respond(message, printf(api.strings.INVALID_ENGINE, args[1])); | ||||
|         } | ||||
|     }); | ||||
|     api.registerCommand('random', async (args, message) => { | ||||
|         const files = fs.readdirSync(process.env["VOICE_TMP_PATH"]); | ||||
|         const rnd = files[Math.floor(Math.random()*files.length)]; | ||||
|         console.log(rnd); | ||||
|         api.queue.add(__dirname + "/../../sysmsg.wav"); | ||||
|         api.queue.add(process.env["VOICE_TMP_PATH"] + "/" + rnd); | ||||
|     }); | ||||
| } | ||||
| @@ -1,32 +1,33 @@ | ||||
| const printf=require('printf'); | ||||
| const AudioQueue=require('../../AudioQueue.js') | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     bot.on('voiceStateUpdate', async (oldState, newState) => { | ||||
|         if (newState.member.user.bot) return; | ||||
|         if (oldState.channel && newState.channel) return; | ||||
|         const channel = oldState.channel || newState.channel; | ||||
|         if (!channel) return; | ||||
|         if (channel.members.array().length < 2) { | ||||
|             return await api.leaveChannel(channel); | ||||
|         } | ||||
|         await api.joinChannel(channel); | ||||
|         let joined = false; | ||||
|         if (!oldState.channel) { | ||||
|             joined = true; | ||||
|             let conn=api.getConnectionForVoiceChannel(channel); | ||||
|             api.queue=new AudioQueue(conn); | ||||
|         } | ||||
|  | ||||
|         let username = newState.member.displayName; | ||||
|         let str = ""; | ||||
|         if (!joined) { | ||||
|             str = printf(api.strings.USER_LEFT, username); | ||||
|         } else { | ||||
|             str = printf(api.strings.USER_JOINED, username); | ||||
|         } | ||||
|         const filepath = await api.generateVoice(str, api.announcementEngine, api.announcementVoice); | ||||
|         api.queue.add(__dirname + "/sysmsg.wav"); | ||||
|         api.queue.add(filepath); | ||||
|     }) | ||||
| } | ||||
| const printf=require('printf'); | ||||
| const AudioQueue=require('../../AudioQueue.js') | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     bot.on('voiceStateUpdate', async (oldState, newState) => { | ||||
|         console.log("Voice state update"); | ||||
|         if (newState.member.user.bot) return; | ||||
|         if (oldState.channel && newState.channel) return; | ||||
|         const channel = oldState.channel || newState.channel; | ||||
|         if (!channel) return; | ||||
|         if (channel.members.size < 1) { | ||||
|             return await api.leaveChannel(channel); | ||||
|         } | ||||
|         await api.joinChannel(channel); | ||||
|         let joined = false; | ||||
|         if (!oldState.channel) { | ||||
|             joined = true; | ||||
|             let conn=api.getConnectionForVoiceChannel(channel); | ||||
|             api.queue=new AudioQueue(conn, api); | ||||
|         } | ||||
|  | ||||
|         let username = newState.member.displayName; | ||||
|         let str = ""; | ||||
|         if (!joined) { | ||||
|             str = printf(api.strings.USER_LEFT, username); | ||||
|         } else { | ||||
|             str = printf(api.strings.USER_JOINED, username); | ||||
|         } | ||||
|         const filepath = await api.generateVoice(str, api.announcementEngine, api.announcementVoice); | ||||
|         api.queue.add(__dirname + "/sysmsg.wav"); | ||||
|         api.queue.add(filepath); | ||||
|     }) | ||||
| } | ||||
|   | ||||
							
								
								
									
										20
									
								
								modules/chatgpt/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								modules/chatgpt/index.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| let ChatGPTAPI = null; | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     import("chatgpt").then((mod) => { | ||||
|         ChatGPTAPI = mod.ChatGPTAPI; | ||||
|     }); | ||||
|     api.registerCommand('chat', async (args, message) => { | ||||
|         const response = await getChatGPTResponse(message.content.slice(6).trim()); | ||||
|         api.respond(message, response); | ||||
|     }); | ||||
| } | ||||
|  | ||||
| async function getChatGPTResponse(prompt) { | ||||
|     const api = new ChatGPTAPI({ | ||||
|         apiKey: process.env.OPENAI_API_KEY | ||||
|     }) | ||||
|  | ||||
|     const res = await api.sendMessage(prompt); | ||||
|     return res.text; | ||||
| } | ||||
| @@ -1,16 +1,17 @@ | ||||
| const fetch = require('node-fetch'); | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     api.registerCommand('randomquote', async (args, message) => { | ||||
|         const data = await fetch(process.env["QDB_URL"], { | ||||
|             headers: { | ||||
|                 Authorization: 'Basic ' + Buffer.from(`${process.env["QDB_USER"]}:${process.env["QDB_PASS"]}`).toString('base64') | ||||
|             } | ||||
|         }); | ||||
|         const quotes = await data.json(); | ||||
|         const quote = quotes[Math.floor(Math.random()*quotes.length)]; | ||||
|         let chan=message.member.voice.channel; | ||||
|         api.queue.add(__dirname + "/sysmsg.wav"); | ||||
|         api.speak(chan, `${quote.author}, on ${quote.medium}: ${quote.quote}`); | ||||
|     }) | ||||
| const fetch = require('node-fetch'); | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     api.registerCommand('randomquote', async (args, message) => { | ||||
|         const data = await fetch(process.env["QDB_URL"], { | ||||
|             headers: { | ||||
|                 Authorization: 'Basic ' + Buffer.from(`${process.env["QDB_USER"]}:${process.env["QDB_PASS"]}`).toString('base64') | ||||
|             } | ||||
|         }); | ||||
|         const quotes = await data.json(); | ||||
|         const quote = quotes[Math.floor(Math.random()*quotes.length)]; | ||||
|         let chan=message.member.voice.channel; | ||||
|         // api.queue.add(__dirname + "/sysmsg.wav"); | ||||
|         // api.speak(chan, `${quote.author}, on ${quote.medium}: ${quote.quote}`); | ||||
|         api.respond(message, `Here's your quote: ${quote.author}, on ${author.medium}: ${quote.quote}`); | ||||
|     }) | ||||
| } | ||||
| @@ -1,23 +1,23 @@ | ||||
| const printf=require('printf'); | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
| 	api.registerCommand('announcevoice', (args, message) => { | ||||
| 		let channel = bot.voice.connections.first().channel; | ||||
| 		if (args.length > 3) { | ||||
| 			return api.respond(message, printf(api.strings.TOO_MANY_ARGUMENTS)); | ||||
| 		} | ||||
| 		if (api.ttsEngines[args[1]]) { | ||||
| 			api.announcementEngine = api.ttsEngines[args[1]]; | ||||
| 			if (api.announcementEngine.validateVoice(args[2])) { | ||||
| 				api.announcementVoice = args[2]; | ||||
| 				api.respond(message, printf(api.strings.SYSTEM_VOICE_CHANGED, api.announcementVoice, api.announcementEngine.longName)); | ||||
| 			} else { | ||||
| 				api.announcementVoice = api.announcementEngine.getDefaultVoice(); | ||||
| 				api.respond(message, printf(api.strings.INVALID_VOICE, api.announcementVoice, api.announcementEngine.longName)); | ||||
| 			} | ||||
| 		} else { | ||||
| 			api.respond(message, printf(api.strings.INVALID_ENGINE, args[1])); | ||||
| 		} | ||||
| 	}); | ||||
| 	api.registerCommand('flush',()=>api.queue.flush()); | ||||
| const printf=require('printf'); | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
| 	api.registerCommand('announcevoice', (args, message) => { | ||||
| 		let channel = api.getActiveVoiceChannel(); | ||||
| 		if (args.length > 3) { | ||||
| 			return api.respond(message, printf(api.strings.TOO_MANY_ARGUMENTS)); | ||||
| 		} | ||||
| 		if (api.ttsEngines[args[1]]) { | ||||
| 			api.announcementEngine = api.ttsEngines[args[1]]; | ||||
| 			if (api.announcementEngine.validateVoice(args[2])) { | ||||
| 				api.announcementVoice = args[2]; | ||||
| 				api.respond(message, printf(api.strings.SYSTEM_VOICE_CHANGED, api.announcementVoice, api.announcementEngine.longName)); | ||||
| 			} else { | ||||
| 				api.announcementVoice = api.announcementEngine.getDefaultVoice(); | ||||
| 				api.respond(message, printf(api.strings.INVALID_VOICE, api.announcementVoice, api.announcementEngine.longName)); | ||||
| 			} | ||||
| 		} else { | ||||
| 			api.respond(message, printf(api.strings.INVALID_ENGINE, args[1])); | ||||
| 		} | ||||
| 	}); | ||||
| 	api.registerCommand('flush',()=>api.queue.flush()); | ||||
| } | ||||
| @@ -1,14 +1,14 @@ | ||||
| const AudioQueue=require('../../AudioQueue.js') | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     bot.on('ready', async () => { | ||||
|         console.log("Bot initialized and listening"); | ||||
|         const guild = await bot.guilds.fetch(process.env.GUILD); | ||||
|         const channel = await bot.channels.fetch(process.env.CHANNEL); | ||||
|         await api.joinChannel(channel); | ||||
|         let conn=api.getConnectionForVoiceChannel(channel); | ||||
|         api.queue=new AudioQueue(conn); | ||||
|         api.queue.add(__dirname + "/../../sysstart.wav"); | ||||
|         api.speak(channel, api.strings.WELCOME); | ||||
|     }) | ||||
| const AudioQueue=require('../../AudioQueue.js') | ||||
|  | ||||
| module.exports = function (bot, api) { | ||||
|     bot.on('ready', async () => { | ||||
|         console.log("Bot initialized and listening"); | ||||
|         const guild = await bot.guilds.fetch(process.env.GUILD); | ||||
|         const channel = await bot.channels.fetch(process.env.CHANNEL); | ||||
|         await api.joinChannel(channel); | ||||
|         let conn=api.getConnectionForVoiceChannel(channel); | ||||
|         api.queue=new AudioQueue(conn, api); | ||||
|         api.queue.add(__dirname + "/../../sysstart.wav"); | ||||
|         api.speak(channel, api.strings.WELCOME); | ||||
|     }) | ||||
| } | ||||
							
								
								
									
										10040
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										10040
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										64
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										64
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,30 +1,34 @@ | ||||
| { | ||||
|   "name": "tardis-bot", | ||||
|   "version": "1.0.0", | ||||
|   "description": "", | ||||
|   "main": "index.js", | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: no test specified\" && exit 1" | ||||
|   }, | ||||
|   "keywords": [], | ||||
|   "author": "", | ||||
|   "license": "ISC", | ||||
|   "dependencies": { | ||||
|     "@google-cloud/text-to-speech": "^3.1.3", | ||||
|     "discord.js": "^12.5.3", | ||||
|     "dotenv": "^8.2.0", | ||||
|     "fast-levenshtein": "^3.0.0", | ||||
|     "google-tts-api": "^2.0.2", | ||||
|     "is-string-int": "^1.0.1", | ||||
|     "microsoft-cognitiveservices-speech-sdk": "^1.16.0", | ||||
|     "node-fetch": "^2.6.1", | ||||
|     "node-google-translate-skidz": "^1.1.2", | ||||
|     "opusscript": "^0.0.8", | ||||
|     "printf": "^0.6.1", | ||||
|     "sam-js": "^0.1.2", | ||||
|     "sha1": "^1.1.1", | ||||
|     "sqlite": "^4.0.21", | ||||
|     "sqlite3": "^5.0.2", | ||||
|     "wavefile": "^11.0.0" | ||||
|   } | ||||
| } | ||||
| { | ||||
|   "name": "tardis-bot", | ||||
|   "version": "1.0.0", | ||||
|   "description": "", | ||||
|   "main": "index.js", | ||||
|   "scripts": { | ||||
|     "test": "echo \"Error: no test specified\" && exit 1", | ||||
|     "start": "node index.js" | ||||
|   }, | ||||
|   "keywords": [], | ||||
|   "author": "", | ||||
|   "license": "ISC", | ||||
|   "dependencies": { | ||||
|     "@discordjs/voice": "^0.15.0", | ||||
|     "@google-cloud/text-to-speech": "^3.1.3", | ||||
|     "chatgpt": "^5.1.2", | ||||
|     "discord.js": "^14.8.0", | ||||
|     "dotenv": "^8.2.0", | ||||
|     "fast-levenshtein": "^3.0.0", | ||||
|     "google-tts-api": "^2.0.2", | ||||
|     "is-string-int": "^1.0.1", | ||||
|     "libsodium-wrappers": "^0.7.11", | ||||
|     "microsoft-cognitiveservices-speech-sdk": "^1.16.0", | ||||
|     "node-fetch": "^2.6.1", | ||||
|     "node-google-translate-skidz": "^1.1.2", | ||||
|     "opusscript": "^0.0.8", | ||||
|     "printf": "^0.6.1", | ||||
|     "sam-js": "^0.1.2", | ||||
|     "sha1": "^1.1.1", | ||||
|     "sqlite": "^4.0.21", | ||||
|     "sqlite3": "^5.0.2", | ||||
|     "wavefile": "^11.0.0" | ||||
|   } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user