Created and maintained by Adam Ratzman.
This readme will teach you how to deploy Ardent on your local machine and learn how it works.
Clone the project using https://github.com/ArdentDiscord/Ardent-2018.git
or [email protected]:ArdentDiscord/Ardent-2018.git
First, you need the following technologies: Docker and Docker Compose. If you're using Windows (but not 10 Pro), use this link to install the Docker Toolbox, which will install both for you. Use the Docker quickstart terminal. Otherwise, install the version of Docker CE (Community edition) and Docker Compose that are available for your machine here and here (for compose).
Navigate to the Ardent project root directory. You'll need to create a file called test-config
(no extension) to put your API keys. Ardent will load its config from this.
Inside, you need the following structure:
test :: true
token :: DISCORD_BOT_TOKEN_HERE
giphy :: GIPHY_TOKEN_HERE
google :: GOOGLE_TOKEN_HERE
client_secret :: DISCORD_BOT_CLIENT_SECRET_HERE
spotify_client_id :: SPOTIFY_CLIENT_ID
spotify_client_secret :: SPOTIFY_CLIENT_SECRET
error_channel :: TEXT_CHANNEL_ID
There are six straightforward steps to being able to run Ardent, which we'll go over now.
- Create a Discord bot here. You'll find the client secret (client_secret in the config) under
General Information
on the right side. - Go to the
Bot
tab. Create a bot if one isn't already created, then replacetoken
inside the config with your bot token. - Go to the Giphy API site and create an application. Put the API key provided under the
giphy
key in the config. - Go to the Spotify developer dashboard and create an application. Put the client id and secret it gives you under their respective keys in the config.
- This step is a bit complicated and involves integrating the Google Sheets API into the bot, necessary for trivia (and soon, other stuff!).
First, sign into GCP (Google Cloud Platform) with your Google account here. Create a project when it prompts you. It'll take up to a minute to instantiate, so be patient.
Next, click on the 3 menu bars on the top left and go to
APIs & Services
. Click onEnable APIs and Services
and search for theGoogle Sheets API
. ClickEnable
, then click onCredentials
on the left side of the screen. On the dropdown menu, select to create anAPI Key
. Copy the created key and put it as the value of thegoogle
key. - replace the
error_channel
value with the Discord text channel id you want to send error messages to
Cool, you're done with the setup! Ardent takes care of setting up the database on first run, which is stored in a docker volume named rethinkdb
by default (you can change this!).
You need to run this via the Docker Quickstart Terminal if you're using Windows. Otherwise, the command line will work. If you're on a UNIX machine, make sure that docker is running and docker-compose is installed.
Inside the root directory of the project, type
cd compose
sh deploy.sh
to change your working directory and then deploy the bot. Read the deployment script carefully. Though there's nothing in it that would harm your computer, never trust scripts over the internet!
If all goes well, the bot will start up! Note that on the first time you run it, docker needs to pull the rethinkdb:latest
and openjdk:8-jre-slim
images.
Ardent uses a centralized command system that takes advantage of reflection to instantiate commands at runtime. I recommend you begin with the Ardent register to see what components are available. Then, look through the commands directory to understand how commands are defined, processed, and how help is sent. Afterwards, look at a few simple commands (like Ping.kt) to check your understand. Talk to Adam#9261 on our Discord server if you have questions, comments, or are ready to submit a pull request or work on a feature!
When adding functionality (like commands), you are not able to register arguments and flags as part of a command. Thus, don't
worry about localizing - instead, use strings with the built-in Sender functions, and check for parameters using
str.equals(other, true)
. When you submit a pull rqeuest, after testing your feature, I will localize all added
strings and commands.
Since you don't have API access to Ardent's crowdin, you'll use a local zip file containing translations. As they're not updated in real time, they may get out of date. Make sure to pull regularly.
Even though you can substitute OpenJDK with the Oracle JRE (though good luck with the legality of that) or run Ardent on your local machine, we use OpenJDK and Docker to ensure portabilit. Though you can change the version in Dockerfile.ardent.test, make sure it's not an alpine-based image, or else playing music will crash the JVM.