2017-05-23 17:19:15 +00:00
|
|
|
package me.savvy.rixa;
|
|
|
|
|
2017-05-24 13:16:39 +00:00
|
|
|
import me.savvy.rixa.commands.admin.BatchMoveCommand;
|
2017-05-23 17:19:15 +00:00
|
|
|
import me.savvy.rixa.commands.general.HelpCommand;
|
|
|
|
import me.savvy.rixa.commands.general.InfoCommand;
|
2017-05-24 13:16:39 +00:00
|
|
|
import me.savvy.rixa.commands.general.PingCommand;
|
2017-05-23 17:19:15 +00:00
|
|
|
import me.savvy.rixa.commands.general.ServerInfoCommand;
|
2017-05-24 13:16:39 +00:00
|
|
|
import me.savvy.rixa.commands.handlers.CommandExec;
|
2017-05-23 17:19:15 +00:00
|
|
|
import me.savvy.rixa.commands.handlers.CommandHandler;
|
2017-05-24 13:16:39 +00:00
|
|
|
import me.savvy.rixa.commands.mod.DeleteMessagesCommand;
|
2017-05-29 22:31:22 +00:00
|
|
|
import me.savvy.rixa.commands.mod.PurgeMessagesCommand;
|
2017-06-04 23:00:58 +00:00
|
|
|
import me.savvy.rixa.data.database.Data;
|
|
|
|
import me.savvy.rixa.data.database.DataType;
|
|
|
|
import me.savvy.rixa.data.database.sql.DatabaseManager;
|
|
|
|
import me.savvy.rixa.data.filemanager.ConfigManager;
|
|
|
|
import me.savvy.rixa.data.filemanager.LanguageManager;
|
2017-05-24 13:16:39 +00:00
|
|
|
import me.savvy.rixa.events.BotEvent;
|
2017-05-23 17:19:15 +00:00
|
|
|
import me.savvy.rixa.events.MessageEvent;
|
|
|
|
import me.savvy.rixa.modules.reactions.handlers.ReactionManager;
|
|
|
|
import me.savvy.rixa.modules.reactions.react.HelpReaction;
|
|
|
|
import net.dv8tion.jda.core.AccountType;
|
|
|
|
import net.dv8tion.jda.core.JDA;
|
|
|
|
import net.dv8tion.jda.core.JDABuilder;
|
|
|
|
import net.dv8tion.jda.core.OnlineStatus;
|
|
|
|
import net.dv8tion.jda.core.entities.Game;
|
|
|
|
import net.dv8tion.jda.core.exceptions.RateLimitedException;
|
|
|
|
import net.dv8tion.jda.core.hooks.AnnotatedEventManager;
|
|
|
|
|
|
|
|
import javax.security.auth.login.LoginException;
|
|
|
|
import java.util.LinkedList;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Created by Timber on 5/7/2017.
|
|
|
|
*/
|
|
|
|
public class Rixa {
|
|
|
|
|
2017-06-04 23:00:58 +00:00
|
|
|
private static Data data;
|
|
|
|
private static long timeUp;
|
|
|
|
private static Rixa instance;
|
2017-05-23 17:19:15 +00:00
|
|
|
private static List<JDA> shardsList;
|
2017-06-04 23:00:58 +00:00
|
|
|
private static ConfigManager config;
|
2017-05-29 22:31:22 +00:00
|
|
|
private static DatabaseManager dbManager;
|
2017-06-04 23:00:58 +00:00
|
|
|
private LanguageManager languageManager;
|
|
|
|
// String search = event.getMessage().getContent().substring(event.getMessage().getContent().indexOf(" ") + 1);
|
2017-05-29 22:31:22 +00:00
|
|
|
public static void main(String[] args) {
|
2017-05-23 17:19:15 +00:00
|
|
|
instance = new Rixa();
|
|
|
|
shardsList = new LinkedList<>();
|
2017-06-04 23:00:58 +00:00
|
|
|
config = new ConfigManager();
|
2017-05-29 22:31:22 +00:00
|
|
|
load();
|
2017-05-23 17:19:15 +00:00
|
|
|
}
|
|
|
|
|
2017-05-29 22:31:22 +00:00
|
|
|
private static void load() {
|
2017-06-04 23:00:58 +00:00
|
|
|
dbManager = new DatabaseManager(
|
|
|
|
String.valueOf(config.getConfig().getObjectinObj("sql", "hostName")),
|
|
|
|
String.valueOf(config.getConfig().getObjectinObj("sql", "portNumber")),
|
|
|
|
String.valueOf(config.getConfig().getObjectinObj("sql", "databaseName")),
|
|
|
|
String.valueOf(config.getConfig().getObjectinObj("sql", "userName")),
|
|
|
|
String.valueOf(config.getConfig().getObjectinObj("sql", "password")));
|
2017-05-29 22:31:22 +00:00
|
|
|
dbManager.createTable();
|
2017-06-04 23:00:58 +00:00
|
|
|
getInstance().setLanguageManager(new LanguageManager());
|
2017-05-29 22:31:22 +00:00
|
|
|
try {
|
|
|
|
int shards = 3;
|
|
|
|
for(int i = 0; i < shards; i++) {
|
|
|
|
Logger.getLogger("Rixa").info("Loading shard #" + i);
|
|
|
|
JDABuilder jda = new JDABuilder(AccountType.BOT)
|
2017-06-04 23:00:58 +00:00
|
|
|
.setToken(config.getConfig().getString("secretToken"))
|
2017-05-29 22:31:22 +00:00
|
|
|
.setEventManager(new AnnotatedEventManager())
|
|
|
|
.addEventListener(new MessageEvent())
|
2017-06-04 23:00:58 +00:00
|
|
|
.addEventListener(new BotEvent())
|
|
|
|
.setGame(Game.of(config.getConfig().getString("botGame")))
|
|
|
|
.setAutoReconnect(true)
|
2017-05-29 22:31:22 +00:00
|
|
|
.setStatus(OnlineStatus.ONLINE)
|
|
|
|
.setAudioEnabled(true)
|
|
|
|
.useSharding(i, shards);
|
|
|
|
shardsList.add(jda.buildBlocking());
|
|
|
|
getInstance().getLogger().info("Shard #" + i + " has been loaded");
|
|
|
|
}
|
|
|
|
} catch (LoginException | InterruptedException | RateLimitedException e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
timeUp = System.currentTimeMillis();
|
|
|
|
register(new CommandExec[] {
|
|
|
|
new InfoCommand(), new ServerInfoCommand(), new HelpCommand(),
|
|
|
|
new DeleteMessagesCommand(), new PingCommand(), new PurgeMessagesCommand(),
|
|
|
|
new BatchMoveCommand() });
|
|
|
|
ReactionManager.registerReaction(new HelpReaction());
|
2017-06-04 23:00:58 +00:00
|
|
|
data = new Data(DataType.SQL);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Data getData() {
|
|
|
|
return data;
|
2017-05-29 22:31:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public DatabaseManager getDbManager() {
|
|
|
|
return dbManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setDbManager(DatabaseManager dbManager) {
|
2017-06-04 23:00:58 +00:00
|
|
|
Rixa.dbManager = dbManager;
|
2017-05-29 22:31:22 +00:00
|
|
|
}
|
|
|
|
|
2017-06-04 23:00:58 +00:00
|
|
|
public LanguageManager getLanguageManager() {
|
|
|
|
return languageManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
private void setLanguageManager(LanguageManager languageManager) {
|
|
|
|
this.languageManager = languageManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void register(CommandExec commandExecs[]) {
|
|
|
|
for (CommandExec command: commandExecs) {
|
|
|
|
CommandHandler.registerCommand(command);
|
2017-05-29 22:31:22 +00:00
|
|
|
}
|
|
|
|
}
|
2017-06-04 23:00:58 +00:00
|
|
|
|
|
|
|
public static Rixa getInstance() {
|
|
|
|
return instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
public long getTimeUp() {
|
|
|
|
return timeUp;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Logger getLogger() {
|
|
|
|
return Logger.getLogger("Rixa");
|
|
|
|
}
|
2017-05-23 17:19:15 +00:00
|
|
|
}
|