This is a simple TTS Bot that uses the Google Translate TTS API. With this bot you can send Text-to-Speech messages in multiple languages.
To self-host this bot you'll need the following:
ffmpeg should be installed by default on Linux and MacOS, in case it isn't, install it with your package manager. For Windows users, head over to ffmpeg's official website to download the binary which will need to be added to your $PATH. If you don't know how to add folders to your $PATH, check out this guide.
In order to self-host this bot, first you'll need to clone this repository.
git clone https://github.com/moonstar-x/discord-tts-bot.git
Then, inside the config
folder, rename the file settings.json.example to settings.json and edit the file with your own Discord Token and the prefix you wish to use. If you don't have a discord token yet, you can see a guide on how to create it here. Your file should look like this.
{
"discord_token": "YOUR_DISCORD_TOKEN",
"prefix": "$",
"allow_more_than_200_chars": "yes"
}
The allow_more_than_200_chars
property lets you choose wether you want TTS messages longer than 200 characters to be played (default: yes
).
Install the dependencies:
npm install
You can now run your bot:
npm start
To deploy to Heroku, you can click on the image below and login to your account.
You can now go back to your app's Overview, make sure you disable the web dyno and enable the bot dyno. Your bot should now be up and running. Remember you can always check your bot's console if you access the View Logs in the More dropdown menu.
Here's a list of all the commands for the bot:
Command | Description |
---|---|
$say <message> | Send a TTS message in your voice channel. |
$aeiou <message> | Send an aeiou (similar to Moonbase Alpha) TTS message in your voice channel. |
$stop | Stop the TTS bot and leave the channel. |
$lang <lang_code> | Change the TTS language. |
$langs | Display a list of the supported languages. |
$speed <number> | Change the TTS spoken speed (must be between 1% and 100%). |
$help | Display a help message with all the available commands. |
Up until now, these settings are saved in memory, which means if the bot crashes/restarts, all of these settings will go back to default (
Language: English, Speed: 100%
).
Here's a list of all the supported languages:
Language Code | Language Name |
---|---|
af | Afrikaans |
hy | Armenian |
id | Indonesian |
bn | Bengali |
ca | Catalan |
cs | Czech |
da | Danish |
de | German |
en | English |
es | Spanish |
fil | Filipino |
fr | French |
hr | Croatian |
is | Icelandic |
it | Italian |
jv | Javanese |
km | Khmer |
lv | Latvian |
hu | Hungarian |
ml | Malayalam |
mr | Marathi |
nl | Dutch |
ne | Nepali |
nb | Norwegian |
pl | Polish |
pt | Portuguese |
ro | Romanian |
si | Sinhala |
sk | Slovak |
su | Sundanese |
sw | Swahili |
fi | Finnish |
sv | Swedish |
ta | Tamil |
te | Telugu |
vi | Vietnamese |
tr | Turkish |
el | Greek |
ru | Russian |
sr | Serbian |
uk | Ukranian |
ar | Arabic |
hi | Hindi |
th | Thai |
ko | Korean |
cmn | Chinese |
ja | Japanese |
You can add this bot to your server by clicking the image below:
This bot was made by moonstar-x.