Clan MOTD + rank cmd fixes

This commit is contained in:
Vortrex
2022-07-27 00:42:59 -05:00
parent 225d78c60d
commit 2efccb638f

View File

@@ -37,7 +37,9 @@ class ClanData {
this.enabled = intToBool(toInteger(dbAssoc["clan_enabled"])); this.enabled = intToBool(toInteger(dbAssoc["clan_enabled"]));
this.colour = toColour(toInteger(dbAssoc["clan_col_r"]), toInteger(dbAssoc["clan_col_g"]), toInteger(dbAssoc["clan_col_b"])); this.colour = toColour(toInteger(dbAssoc["clan_col_r"]), toInteger(dbAssoc["clan_col_g"]), toInteger(dbAssoc["clan_col_b"]));
this.colours = [toInteger(dbAssoc["clan_col_r"]), toInteger(dbAssoc["clan_col_g"]), toInteger(dbAssoc["clan_col_b"])]; this.colours = [toInteger(dbAssoc["clan_col_r"]), toInteger(dbAssoc["clan_col_g"]), toInteger(dbAssoc["clan_col_b"])];
this.motd = dbAssoc["clan_motd"]; this.motd = toString(dbAssoc["clan_motd"]);
this.discordWebhookURL = toString(dbAssoc["clan_discord_webhook_url"]);
this.discordWebhookFlags = toInteger(dbAssoc["clan_discord_webhook_flags"]);
} }
} }
}; };
@@ -405,6 +407,60 @@ function setClanNameCommand(command, params, client) {
// =========================================================================== // ===========================================================================
function setClanMOTDCommand(command, params, client) {
if (!doesPlayerHaveClanPermission(client, getClanFlagValue("ClanMOTD"))) {
messagePlayerError(client, "You can not change the clan MOTD!");
return false;
}
if (areParamsEmpty(params)) {
messagePlayerSyntax(client, getCommandSyntaxText(command));
return false;
}
let clanId = getPlayerClan(client);
if (!getClanData(clanId)) {
messagePlayerError(client, getLocaleString(client, "InvalidClan"));
return false;
}
getClanData(clanId).motd = params;
getClanData(clanId).needsSaved = true;
//messageAdmins(`{adminOrange}${getPlayerName(client)} {MAINCOLOUR}set clan {clanOrange}${getClanData(clanId).index} {MAINCOLOUR}name to {ALTCOLOUR}${params}`);
messagePlayerSuccess(client, `You changed the clan message of the day to {ALTCOLOUR}${params}`);
}
// ===========================================================================
function setClanDiscordWebhookCommand(command, params, client) {
if (!doesPlayerHaveClanPermission(client, getClanFlagValue("ClanDiscordWebhook"))) {
messagePlayerError(client, "You can not change the clan discord webhook!");
return false;
}
if (areParamsEmpty(params)) {
messagePlayerSyntax(client, getCommandSyntaxText(command));
return false;
}
let clanId = getPlayerClan(client);
if (!getClanData(clanId)) {
messagePlayerError(client, getLocaleString(client, "InvalidClan"));
return false;
}
getClanData(clanId).discordWebhook = params;
getClanData(clanId).needsSaved = true;
//messageAdmins(`{adminOrange}${getPlayerName(client)} {MAINCOLOUR}set clan {clanOrange}${getClanData(clanId).index} {MAINCOLOUR}name to {ALTCOLOUR}${params}`);
messagePlayerSuccess(client, `You changed the clan discord webhook!`);
}
// ===========================================================================
function createClanRankCommand(command, params, client) { function createClanRankCommand(command, params, client) {
if (!doesPlayerHaveClanPermission(client, getClanFlagValue("ManageRanks"))) { if (!doesPlayerHaveClanPermission(client, getClanFlagValue("ManageRanks"))) {
messagePlayerError(client, "You can not add new clan ranks!"); messagePlayerError(client, "You can not add new clan ranks!");
@@ -423,13 +479,14 @@ function createClanRankCommand(command, params, client) {
return false; return false;
} }
let splitParams = params.split(" ");
let rankId = toInteger(getParam(params, " ", 1)); let rankId = toInteger(getParam(params, " ", 1));
let rankName = getParam(params, " ", 2); let rankName = splitParams.slice(-1).join(" ");
let rankIndex = createClanRank(clanId, rankId, rankName); let rankIndex = createClanRank(clanId, rankId, rankName);
messagePlayerSuccess(client, `You added the {ALTCOLOUR}${rankName} {MAINCOLOUR}rank (Level {ALTCOLOUR}${rankId}`); messagePlayerSuccess(client, `You added the {ALTCOLOUR}${rankName} {MAINCOLOUR}rank (Level {ALTCOLOUR}${rankId}`);
messagePlayerSuccess(client, `Use {ALTCOLOUR}/addclanrankflag ${rankName} <clan flag name> {MAINCOLOUR} to add permission flags to this rank.`); messagePlayerSuccess(client, `Use {ALTCOLOUR}/clanaddrankflag ${rankName} <clan flag name> {MAINCOLOUR} to add permission flags to this rank.`);
} }
// =========================================================================== // ===========================================================================
@@ -456,7 +513,7 @@ function deleteClanRankCommand(command, params, client) {
let tempRankName = getClanRankData(clanId, rankId); let tempRankName = getClanRankData(clanId, rankId);
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
@@ -524,11 +581,12 @@ function setClanRankTagCommand(command, params, client) {
return false; return false;
} }
let splitParams = params.split(" ");
let rankId = getClanRankFromParams(clanId, splitParams.slice(0, -1)); let rankId = getClanRankFromParams(clanId, splitParams.slice(0, -1));
let newTag = splitParams[splitParams.length - 1]; let newTag = splitParams.slice(-1);
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
@@ -563,11 +621,12 @@ function setClanRankLevelCommand(command, params, client) {
return false; return false;
} }
let splitParams = params.split(" ");
let rankId = getClanRankFromParams(clanId, splitParams.slice(0, -1)); let rankId = getClanRankFromParams(clanId, splitParams.slice(0, -1));
let newLevel = splitParams[splitParams.length - 1]; let newLevel = splitParams.slice(-1);
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
@@ -638,7 +697,14 @@ function addClanMemberFlagCommand(command, params, client) {
} }
} }
let flagValue = getClanFlagValue(getParam(params, " ", 2)); let flagName = getParam(params, " ", 2);
let flagValue = getClanFlagValue(flagName);
if (!flagValue) {
messagePlayerError(client, "Clan flag not found!");
return false;
}
getPlayerCurrentSubAccount(client).clanFlags = getPlayerCurrentSubAccount(client).clanFlags | flagValue; getPlayerCurrentSubAccount(client).clanFlags = getPlayerCurrentSubAccount(client).clanFlags | flagValue;
messagePlayerSuccess(client, `You added the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag to {ALTCOLOUR}${getCharacterFullName(client)}`); messagePlayerSuccess(client, `You added the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag to {ALTCOLOUR}${getCharacterFullName(client)}`);
} }
@@ -689,7 +755,14 @@ function removeClanMemberFlagCommand(command, params, client) {
} }
} }
let flagValue = getClanFlagValue(getParam(params, " ", 2)); let flagName = getParam(params, " ", 2);
let flagValue = getClanFlagValue(flagName);
if (!flagValue) {
messagePlayerError(client, "Clan flag not found!");
return false;
}
getPlayerCurrentSubAccount(client).clanFlags = getPlayerCurrentSubAccount(client).clanFlags & ~flagValue; getPlayerCurrentSubAccount(client).clanFlags = getPlayerCurrentSubAccount(client).clanFlags & ~flagValue;
messagePlayerSuccess(client, `You removed the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag from {ALTCOLOUR}${getCharacterFullName(client)}`); messagePlayerSuccess(client, `You removed the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag from {ALTCOLOUR}${getCharacterFullName(client)}`);
} }
@@ -714,20 +787,22 @@ function addClanRankFlagCommand(command, params, client) {
return false; return false;
} }
let rankId = getClanRankFromParams(clanId, getParam(params, " ", 1)); let splitParams = params.split(" ");
let rankId = getClanRankFromParams(clanId, splitParams.slice(0, -1));
let flagName = splitParams.slice(-1);
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
if (!getClanFlagValue(getParam(params, " ", 2))) { let flagValue = getClanFlagValue(flagName);
if (!flagValue) {
messagePlayerError(client, "Clan flag not found!"); messagePlayerError(client, "Clan flag not found!");
return false; return false;
} }
let flagValue = getClanFlagValue(getParam(params, " ", 2));
getClanRankData(clanId, rankId).flags = addBitFlag(getClanRankData(clanId, rankId).flags, flagValue); getClanRankData(clanId, rankId).flags = addBitFlag(getClanRankData(clanId, rankId).flags, flagValue);
getClanRankData(clanId, rankId).needsSaved = true; getClanRankData(clanId, rankId).needsSaved = true;
messagePlayerSuccess(client, `You added the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag to rank {ALTCOLOUR}${getClanRankData(clanId, rankId).name}`); messagePlayerSuccess(client, `You added the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag to rank {ALTCOLOUR}${getClanRankData(clanId, rankId).name}`);
@@ -753,20 +828,22 @@ function removeClanRankFlagCommand(command, params, client) {
return false; return false;
} }
let rankId = getClanRankFromParams(clanId, getParam(params, " ", 1)); let splitParams = params.split(" ");
let rankId = getClanRankFromParams(clanId, splitParams.slice(0, -1));
let flagName = splitParams.slice(-1);
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
if (!getClanFlagValue(getParam(params, " ", 2))) { let flagValue = getClanFlagValue(flagName);
if (!flagValue) {
messagePlayerError(client, "Clan flag not found!"); messagePlayerError(client, "Clan flag not found!");
return false; return false;
} }
let flagValue = getClanFlagValue(getParam(params, " ", 2));
getClanRankData(clanId, rankId).flags = removeBitFlag(getClanRankData(clanId, rankId).flags, flagValue); getClanRankData(clanId, rankId).flags = removeBitFlag(getClanRankData(clanId, rankId).flags, flagValue);
getClanRankData(clanId, rankId).needsSaved = true; getClanRankData(clanId, rankId).needsSaved = true;
messagePlayerSuccess(client, `You removed the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag from rank {ALTCOLOUR}${getClanRankData(clanId, rankId).name}`); messagePlayerSuccess(client, `You removed the {ALTCOLOUR}${getParam(params, " ", 2)} {MAINCOLOUR}clan flag from rank {ALTCOLOUR}${getClanRankData(clanId, rankId).name}`);
@@ -792,10 +869,10 @@ function showClanRankFlagsCommand(command, params, client) {
return false; return false;
} }
let rankId = getClanRankFromParams(clanId, getParam(params, " ", 1)); let rankId = getClanRankFromParams(clanId, params);
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
@@ -812,7 +889,7 @@ function showClanRankFlagsCommand(command, params, client) {
let chunkedList = splitArrayIntoChunks(flagList, 6); let chunkedList = splitArrayIntoChunks(flagList, 6);
makeChatBoxSectionHeader(client, getLocaleString(client, "ClanRankFlags"), getClanRankData(clanId, rankId).name); makeChatBoxSectionHeader(client, getLocaleString(client, "HeaderClanRankFlags", getClanRankData(clanId, rankId).name));
for (let i in chunkedList) { for (let i in chunkedList) {
messagePlayerInfo(client, chunkedList[i].join("{MAINCOLOUR}, ")); messagePlayerInfo(client, chunkedList[i].join("{MAINCOLOUR}, "));
} }
@@ -877,24 +954,26 @@ function setClanRankTitleCommand(command, params, client) {
return false; return false;
} }
let clanId = getPlayerClan(client); let clanIndex = getPlayerClan(client);
if (!getClanData(clanId)) { if (!getClanData(clanIndex)) {
messagePlayerError(client, getLocaleString(client, "InvalidClan")); messagePlayerError(client, getLocaleString(client, "InvalidClan"));
return false; return false;
} }
let rankId = getClanRankFromParams(clanId, getParam(params, " ", 1)); let splitParams = params.split(" ");
let rankIndex = getClanRankFromParams(clanIndex, getParam(params, " ", 1));
let rankName = splitParams.slice(1).join(" ");
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanIndex, rankIndex)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
let oldRankName = getClanRankData(clanId, rankId).name; let oldRankName = getClanRankData(clanIndex, rankIndex).name;
getClanRankData(clanId, rankId).name = getParam(params, " ", 2); getClanRankData(clanIndex, rankIndex).name = rankName
getClanRankData(clanId, rankId).needsSaved = true; getClanRankData(clanIndex, rankIndex).needsSaved = true;
messagePlayerSuccess(client, `You changed the name of rank ${rankId} from {ALTCOLOUR}${oldRankName} {MAINCOLOUR}to {ALTCOLOUR}${params}`); messagePlayerSuccess(client, `You changed the name of rank {ALTCOLOUR}${rankIndex}{MAINCOLOUR} from {ALTCOLOUR}${oldRankName}{MAINCOLOUR} to {ALTCOLOUR}${rankName}`);
} }
// =========================================================================== // ===========================================================================
@@ -917,8 +996,9 @@ function setClanMemberRankCommand(command, params, client) {
return false; return false;
} }
let splitParams = params.split(" ");
let targetClient = getPlayerFromParams(getParam(params, " ", 1)); let targetClient = getPlayerFromParams(getParam(params, " ", 1));
let rankId = getClanRankFromParams(clanId, getParam(params, " ", 2)); let rankId = getClanRankFromParams(clanId, splitParams.slice(-1).join(" "));
if (!targetClient) { if (!targetClient) {
messagePlayerError(client, getLocaleString(client, "InvalidPlayer")); messagePlayerError(client, getLocaleString(client, "InvalidPlayer"));
@@ -926,7 +1006,7 @@ function setClanMemberRankCommand(command, params, client) {
} }
if (!getClanRankData(clanId, rankId)) { if (!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }
@@ -1089,12 +1169,17 @@ function saveClanToDatabase(clanId) {
let safeName = escapeDatabaseString(dbConnection, tempClanData.name); let safeName = escapeDatabaseString(dbConnection, tempClanData.name);
let safeTag = escapeDatabaseString(dbConnection, tempClanData.tag); let safeTag = escapeDatabaseString(dbConnection, tempClanData.tag);
let safeMOTD = escapeDatabaseString(dbConnection, tempClanData.motd); let safeMOTD = escapeDatabaseString(dbConnection, tempClanData.motd);
let safeDiscordWebhookURL = escapeDatabaseString(dbConnection, tempClanData.discordWebhookURL);
let data = [ let data = [
["clan_main", safeName], ["clan_main", safeName],
["clan_owner", tempClanData.ownerId], ["clan_owner", tempClanData.ownerId],
["clan_tag", safeTag], ["clan_tag", safeTag],
["clan_motd", safeMOTD], ["clan_motd", safeMOTD],
["clan_discord_webhook_url", safeDiscordWebhookURL],
["clan_discord_webhook_flags", tempClanData.discordWebhookFlags],
["clan_enabled", boolToInt(tempClanData.enabled)],
["clan_initial_rank", toInteger(tempClanData.initialRank)],
]; ];
let dbQuery = null; let dbQuery = null;
@@ -1238,18 +1323,18 @@ function arePlayersInSameClan(client1, client2) {
// =========================================================================== // ===========================================================================
function getPlayerClanRank(client) { function getPlayerClanRank(client) {
return getPlayerCurrentSubAccount(client).clanRank; return getPlayerCurrentSubAccount(client).clanRankIndex;
} }
// =========================================================================== // ===========================================================================
function getPlayerClan(client) { function getPlayerClan(client) {
return getClanIdFromDatabaseId(getPlayerCurrentSubAccount(client).clan); return getPlayerCurrentSubAccount(client).clanIndex;
} }
// =========================================================================== // ===========================================================================
function getClanIdFromDatabaseId(databaseId) { function getClanIndexFromDatabaseId(databaseId) {
if (databaseId <= 0) { if (databaseId <= 0) {
return -1; return -1;
} }
@@ -1265,31 +1350,37 @@ function getClanIdFromDatabaseId(databaseId) {
// =========================================================================== // ===========================================================================
function getClanRankIdFromDatabaseId(clanId, databaseId) { function getClanRankIndexFromDatabaseId(clanIndex, databaseId) {
for (let i in getServerData().clans[clanId].ranks) { if (databaseId <= 0) {
if (getServerData().clans[clanId].ranks[i].databaseId == databaseId) { return -1;
}
for (let i in getServerData().clans[clanIndex].ranks) {
if (getServerData().clans[clanIndex].ranks[i].databaseId == databaseId) {
return i; return i;
} }
} }
return -1;
} }
// =========================================================================== // ===========================================================================
/** /**
* @param {number} clanId - The data index of the clan * @param {number} clanIndex - The data index of the clan
* @param {number} clanRankId - The data index of the clan rank * @param {number} rankIndex - The data index of the clan rank
* @return {ClanRankData} The clan rank's data (class instance) * @return {ClanRankData} The clan rank's data (class instance)
*/ */
function getClanRankData(clanId, rankId) { function getClanRankData(clanIndex, rankIndex) {
if (clanId == -1) { if (clanIndex == -1) {
return false; return false;
} }
if (rankId == -1) { if (rankIndex == -1) {
return false; return false;
} }
return getServerData().clans[clanId].ranks[rankId]; return getServerData().clans[clanIndex].ranks[rankIndex];
} }
// =========================================================================== // ===========================================================================
@@ -1303,7 +1394,7 @@ function getPlayerSubAccountClanRank(client) {
function getPlayerClanRankName(client) { function getPlayerClanRankName(client) {
if (getPlayerClanRank(client) != 0) { if (getPlayerClanRank(client) != 0) {
let clanId = getPlayerClan(client); let clanId = getPlayerClan(client);
return getClanRankData(clanId, getClanRankIdFromDatabaseId(clanId, getPlayerCurrentSubAccount(client).clanRank)).name; return getClanRankData(clanId, getPlayerClanRank(client)).name;
} else { } else {
return false; return false;
} }
@@ -1347,7 +1438,7 @@ function showClanFlagListCommand(command, params, client) {
let rankId = getClanRankFromParams(clanId, getParam(params, " ", 1)); let rankId = getClanRankFromParams(clanId, getParam(params, " ", 1));
if(!getClanRankData(clanId, rankId)) { if(!getClanRankData(clanId, rankId)) {
messagePlayerError(client, getLocaleString(client, "ClanRankInvalid")); messagePlayerError(client, getLocaleString(client, "InvalidClanRank"));
return false; return false;
} }