mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-20 05:51:35 +02:00
I don't understand
This commit is contained in:
@@ -1,9 +1,8 @@
|
|||||||
const { Command } = require('discord.js-commando');
|
const { Command } = require('discord.js-commando');
|
||||||
const snekfetch = require('snekfetch');
|
const snekfetch = require('snekfetch');
|
||||||
const { Readable } = require('stream');
|
const path = require('path');
|
||||||
// const path = require('path');
|
const { promisifyAll } = require('tsubaki');
|
||||||
// const { promisifyAll } = require('tsubaki');
|
const fs = promisifyAll(require('fs'));
|
||||||
// const fs = promisifyAll(require('fs'));
|
|
||||||
|
|
||||||
module.exports = class DECTalkCommand extends Command {
|
module.exports = class DECTalkCommand extends Command {
|
||||||
constructor(client) {
|
constructor(client) {
|
||||||
@@ -40,21 +39,28 @@ module.exports = class DECTalkCommand extends Command {
|
|||||||
}
|
}
|
||||||
if (!channel.joinable) return msg.say('Your voice channel is not joinable.');
|
if (!channel.joinable) return msg.say('Your voice channel is not joinable.');
|
||||||
if (this.client.voiceConnections.has(channel.guild.id)) return msg.say('I am already playing a sound.');
|
if (this.client.voiceConnections.has(channel.guild.id)) return msg.say('I am already playing a sound.');
|
||||||
|
const file = path.join(__dirname, '..', '..', 'assets', `dec-talk ${channel.guild.id}.wav`);
|
||||||
try {
|
try {
|
||||||
const connection = await channel.join();
|
const connection = await channel.join();
|
||||||
const { body } = await snekfetch
|
const { body } = await snekfetch
|
||||||
.get('http://tts.cyzon.us/tts')
|
.get('http://tts.cyzon.us/tts')
|
||||||
.query({ text });
|
.query({ text });
|
||||||
const stream = new Readable();
|
await fs.writeFileAsync(file, body, { encoding: 'binary' });
|
||||||
stream.read = function () {};
|
const dispatcher = connection.playFile(file);
|
||||||
stream.push(body);
|
dispatcher.once('end', () => this.finish(file, channel));
|
||||||
const dispatcher = connection.playStream(stream);
|
dispatcher.once('error', () => this.finish(file, channel));
|
||||||
dispatcher.once('end', () => channel.leave());
|
|
||||||
dispatcher.once('error', () => channel.leave());
|
|
||||||
return null;
|
return null;
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
channel.leave();
|
await this.finish(file, channel);
|
||||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async finish(file, channel) {
|
||||||
|
try {
|
||||||
|
if (fs.existsSync(file)) await fs.unlinkAsync(file);
|
||||||
|
} finally {
|
||||||
|
channel.leave();
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user