Update to latest bot template code
This commit is contained in:
parent
8da4862a9d
commit
790804a73f
|
@ -1,11 +1,18 @@
|
||||||
{
|
{
|
||||||
"saveIntervalSec": 60,
|
|
||||||
"feedCheckIntervalSec": 30,
|
"feedCheckIntervalSec": 30,
|
||||||
"maxCacheSize": 10,
|
"maxCacheSize": 10,
|
||||||
|
"generic": {
|
||||||
|
"saveFile": "./guilds.json",
|
||||||
|
"saveIntervalSec": 60,
|
||||||
|
"defaultDMResponse": "This bot does not have any handling for direct messages. To learn more or get help please visit http://benji7425.github.io, or join my Discord server here: https://discord.gg/SSkbwSJ"
|
||||||
|
},
|
||||||
"commands": {
|
"commands": {
|
||||||
"version": "version",
|
"admin": {
|
||||||
"addFeed": "add-feed",
|
"version": "version",
|
||||||
"removeFeed": "remove-feed",
|
"addFeed": "add-feed",
|
||||||
"viewFeeds": "view-feeds"
|
"removeFeed": "remove-feed",
|
||||||
|
"viewFeeds": "view-feeds"
|
||||||
|
},
|
||||||
|
"anyone": {}
|
||||||
}
|
}
|
||||||
}
|
}
|
29
app/index.js
29
app/index.js
|
@ -14,13 +14,13 @@ const GuildData = require("./models/guild-data.js");
|
||||||
const FeedData = require("./models/feed-data.js");
|
const FeedData = require("./models/feed-data.js");
|
||||||
|
|
||||||
//global vars
|
//global vars
|
||||||
const SAVE_FILE = "./guilds.json";
|
let writeFile = null;
|
||||||
|
|
||||||
module.exports = (client, config) => {
|
module.exports = (client, config = null) => {
|
||||||
config = config || require("./config.json");
|
config = config || require("./config.json"); //load config file
|
||||||
|
const guildsData = FileSystem.existsSync(config.generic.saveFile) ? fromJSON(JsonFile.readFileSync(config.generic.saveFile)) : {}; //read data from file, or generate new one if file doesn't exist
|
||||||
const guildsData = FileSystem.existsSync(SAVE_FILE) ? fromJSON(JsonFile.readFileSync(SAVE_FILE)) : {};
|
writeFile = () => JsonFile.writeFile(config.generic.saveFile, guildsData, err => { if (err) DiscordUtil.dateError("Error writing file", err); });
|
||||||
setInterval(() => writeFile(guildsData), config.saveIntervalSec * 1000);
|
setInterval(() => writeFile(), config.generic.saveIntervalSec * 1000); //set interval to save data to file
|
||||||
|
|
||||||
parseLinksInGuilds(client.guilds, guildsData).then(() => writeFile(guildsData))
|
parseLinksInGuilds(client.guilds, guildsData).then(() => writeFile(guildsData))
|
||||||
.then(() => checkFeedsInGuilds(client.guilds, guildsData))
|
.then(() => checkFeedsInGuilds(client.guilds, guildsData))
|
||||||
|
@ -39,7 +39,7 @@ module.exports = (client, config) => {
|
||||||
|
|
||||||
const HandleMessage = {
|
const HandleMessage = {
|
||||||
dm: (client, config, message) => {
|
dm: (client, config, message) => {
|
||||||
message.reply("This bot does not have any handling for direct messages. To learn more or get help please visit http://benji7425.github.io, or join my Discord server here: https://discord.gg/SSkbwSJ");
|
message.reply(config.generic.defaultDMResponse);
|
||||||
},
|
},
|
||||||
text: (client, config, message, guildsData) => {
|
text: (client, config, message, guildsData) => {
|
||||||
//handle admins invoking commands
|
//handle admins invoking commands
|
||||||
|
@ -47,18 +47,19 @@ const HandleMessage = {
|
||||||
&& message.member.permissions.has("ADMINISTRATOR")) //user has admin perms
|
&& message.member.permissions.has("ADMINISTRATOR")) //user has admin perms
|
||||||
{
|
{
|
||||||
const params = message.content.split(" "); //split the message at the spaces
|
const params = message.content.split(" "); //split the message at the spaces
|
||||||
|
|
||||||
|
//check which command was invoked
|
||||||
switch (params[1]) {
|
switch (params[1]) {
|
||||||
//add handling for different commands here
|
case config.commands.admin.version:
|
||||||
case config.commands.version:
|
|
||||||
message.reply("v" + require("../package.json").version);
|
message.reply("v" + require("../package.json").version);
|
||||||
break;
|
break;
|
||||||
case config.commands.addFeed:
|
case config.commands.admin.addFeed:
|
||||||
addFeed(client, guildsData, message, config.maxCacheSize);
|
addFeed(client, guildsData, message, config.maxCacheSize);
|
||||||
break;
|
break;
|
||||||
case config.commands.removeFeed:
|
case config.commands.admin.removeFeed:
|
||||||
removeFeed(client, guildsData, message);
|
removeFeed(client, guildsData, message);
|
||||||
break;
|
break;
|
||||||
case config.commands.viewFeeds:
|
case config.commands.admin.viewFeeds:
|
||||||
viewFeeds(client, guildsData[message.guild.id], message);
|
viewFeeds(client, guildsData[message.guild.id], message);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -141,10 +142,6 @@ function parseLinksInGuilds(guilds, guildsData) {
|
||||||
return Promise.all(promises);
|
return Promise.all(promises);
|
||||||
}
|
}
|
||||||
|
|
||||||
function writeFile(guildsData) {
|
|
||||||
JsonFile.writeFile(SAVE_FILE, guildsData, err => { if (err) DiscordUtil.dateError("Error writing file", err); });
|
|
||||||
}
|
|
||||||
|
|
||||||
function fromJSON(json) {
|
function fromJSON(json) {
|
||||||
const guildsData = Object.keys(json);
|
const guildsData = Object.keys(json);
|
||||||
guildsData.forEach(guildID => { json[guildID] = new GuildData(json[guildID]); });
|
guildsData.forEach(guildID => { json[guildID] = new GuildData(json[guildID]); });
|
||||||
|
|
Loading…
Reference in a new issue