forked from PluralFlux/PluralFlux
discord js (#1)
* clear out fluxer.net * basic discord.js bot with ping, and echo * added creation of webhook * simplifying webhook logic * sending messages as webhook * deleting orignal message * adding sequelize file * commented out pgadmin part while it's not working * adding member sort of working * changing names of values * updating names of values and adding new method in memberHelper * renamed messagehelper function * deleted proxyhelper * passed only channel id into webhook helper methods * added new functions and got update working * changed message match to better reducer * adjusted webhook helper to use actual data * refactored bot.js and removed unused methods
This commit is contained in:
137
helpers/memberHelper.js
Normal file
137
helpers/memberHelper.js
Normal file
@@ -0,0 +1,137 @@
|
||||
import { db } from '../sequelize.js';
|
||||
|
||||
const mh = {};
|
||||
|
||||
const errorEnums = {
|
||||
NO_MEMBER: "No member was found.",
|
||||
NO_NAME_PROVIDED: "No member name was provided for",
|
||||
NO_VALUE: "has not been set for this member.",
|
||||
ADD_ERROR: "Error adding member.",
|
||||
MEMBER_EXISTS: "A member with that name already exists.",
|
||||
USER_NO_MEMBERS: "You have no members created."
|
||||
}
|
||||
|
||||
mh.parse_member_command = async function(author_id, args){
|
||||
console.log(author_id, args);
|
||||
if (!args) {
|
||||
return `${errorEnums.NO_NAME_PROVIDED} querying.`
|
||||
}
|
||||
switch(args[0]) {
|
||||
case 'new':
|
||||
return await add_new_member(author_id, args);
|
||||
case 'delete':
|
||||
return await delete_member(author_id, args);
|
||||
}
|
||||
switch(args[1]) {
|
||||
case 'displayname':
|
||||
return await set_display_name(author_id, args);
|
||||
// case 'proxy':
|
||||
// return await set_proxy(author_id, args);
|
||||
// case 'avatar':
|
||||
// return await set_avatar(author_id, args)
|
||||
default:
|
||||
return await get_member_info(author_id, args);
|
||||
}
|
||||
}
|
||||
|
||||
async function add_new_member(author_id, args) {
|
||||
const member_name = args[1];
|
||||
const display_name = args[2];
|
||||
const proxy = args[3];
|
||||
const propic = args[4];
|
||||
if (!member_name) {
|
||||
return `${errorEnums.NO_NAME_PROVIDED} adding.`;
|
||||
}
|
||||
const member = await get_member_info(author_id, member_name);
|
||||
if (member !== errorEnums.NO_MEMBER) {
|
||||
return errorEnums.MEMBER_EXISTS;
|
||||
}
|
||||
const trimmed_name = display_name ? display_name.replaceAll(' ', '') : null;
|
||||
const trimmed_proxy = proxy ? proxy.trim() : null;
|
||||
return await db.members.create({
|
||||
name: member_name,
|
||||
userid: author_id,
|
||||
displayname: trimmed_name !== null ? display_name : null,
|
||||
proxy: trimmed_proxy,
|
||||
propic: propic
|
||||
}).then((m) => {
|
||||
let success = `Member was successfully added.\nName: ${m.dataValues.name}`
|
||||
success += display_name ? `\nDisplay name: ${m.dataValues.displayname}` : "";
|
||||
success += proxy ? `\nProxy tag: ${m.dataValues.proxy} `: "";
|
||||
success += propic ? `\nProfile picture: ${m.dataValues.proxy} `: "";
|
||||
return success;
|
||||
}).catch(e => {
|
||||
return `${errorEnums.ADD_ERROR}: ${e.message}`;
|
||||
})
|
||||
}
|
||||
|
||||
async function get_member_info(author_id, member_name) {
|
||||
let member = await db.members.findOne({ where: { name: member_name, userid: author_id } });
|
||||
if (member) {
|
||||
let member_info = `Member name: ${member.name}`;
|
||||
member_info += member.displayname ? `\nDisplay name: ${member.displayname}` : '\nDisplay name: unset';
|
||||
member_info += member.proxy ? `\nProxy Tag: ${member.proxy}` : '\nProxy tag: unset';
|
||||
member_info += member.propic ? `\nProfile pic: ${member.propic}` : '\nProfile pic: unset';
|
||||
return member_info;
|
||||
}
|
||||
return errorEnums.NO_MEMBER;
|
||||
}
|
||||
|
||||
async function set_display_name(author_id, args) {
|
||||
const member_name = args[0];
|
||||
const display_name = args[2];
|
||||
const trimmed_name = display_name ? display_name.replaceAll(' ', '') : null;
|
||||
console.log(trimmed_name, display_name);
|
||||
if (!member_name) {
|
||||
return `${errorEnums.NO_NAME_PROVIDED} display name.`;
|
||||
}
|
||||
else if (!display_name || trimmed_name === null ) {
|
||||
let member = await get_member_info(author_id, args);
|
||||
console.log(member.displayname);
|
||||
if (member.displayname) {
|
||||
return `Display name for ${member_name} is: ${member.displayname}.`;
|
||||
}
|
||||
return `Display name ${errorEnums.NO_VALUE}`
|
||||
}
|
||||
console.log(display_name);
|
||||
return await update_member(author_id, args);
|
||||
}
|
||||
|
||||
async function update_member(author_id, args) {
|
||||
const member_name = args[0];
|
||||
const column_Name = args[1];
|
||||
const value = args[2];
|
||||
return await db.members.update({[column_Name]: value}, { where: { name: member_name, userid: author_id } }).then(() => {
|
||||
return `Updated ${column_Name} for ${member_name} to ${value}`;
|
||||
}).catch(e => {
|
||||
return `${errorEnums.NO_MEMBER}: ${e.message}`;
|
||||
});
|
||||
}
|
||||
|
||||
async function delete_member(author_id, args) {
|
||||
const member_name = args[1];
|
||||
if (!member_name) {
|
||||
return `${errorEnums.NO_NAME_PROVIDED} deletion.`;
|
||||
}
|
||||
return await db.members.destroy({ where: { name: member_name, userid: author_id } }).then(() => {
|
||||
return `${member_name} has been deleted.`;
|
||||
}).catch(e => {
|
||||
return `${errorEnums.NO_MEMBER}: ${e.message}`;
|
||||
});
|
||||
}
|
||||
|
||||
mh.get_member_by_proxy = async function(author_id, proxy) {
|
||||
return await db.members.findOne({ where: { userid: author_id, proxy: proxy } }).catch(e => {
|
||||
return `${errorEnums.NO_MEMBER}: ${e.message}`;
|
||||
});
|
||||
}
|
||||
|
||||
mh.get_members_by_author = async function(author_id) {
|
||||
return await db.members.findAll({ where: { userid: author_id } }).catch(e => {
|
||||
// I have no idea how this could possibly happen but better safe than sorry
|
||||
return `${errorEnums.USER_NO_MEMBERS}: ${e.message}`;
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
export const memberHelper = mh;
|
||||
Reference in New Issue
Block a user