Fixed re invite spam to already invited member and enhanced kick permission check
This commit is contained in:
parent
8deb02f29f
commit
cbb7d478a7
@ -48,12 +48,17 @@ public class CmdInvite extends FCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Access access = myFaction.getAccess(fme, PermissableAction.INVITE);
|
if (!fme.isAdminBypassing()) {
|
||||||
if (access == Access.DENY || (access == Access.UNDEFINED && !assertMinRole(Role.MODERATOR))) {
|
Access access = myFaction.getAccess(fme, PermissableAction.INVITE);
|
||||||
fme.msg(TL.GENERIC_FPERM_NOPERMISSION, "invite");
|
if (access == Access.DENY || (access == Access.UNDEFINED && !assertMinRole(Role.MODERATOR))) {
|
||||||
|
fme.msg(TL.GENERIC_FPERM_NOPERMISSION, "invite");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (myFaction.isInvited(target)) {
|
||||||
|
fme.msg(TL.COMMAND_INVITE_ALREADYINVITED, target.getName());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (myFaction.isBanned(target)) {
|
if (myFaction.isBanned(target)) {
|
||||||
fme.msg(TL.COMMAND_INVITE_BANNED, target.getName());
|
fme.msg(TL.COMMAND_INVITE_BANNED, target.getName());
|
||||||
return;
|
return;
|
||||||
|
@ -73,40 +73,31 @@ public class CmdKick extends FCommand {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// players with admin-level "disband" permission can bypass these requirements
|
// This permission check has been cleaned to be more understandable and logical
|
||||||
if (!Permission.KICK_ANY.has(sender)) {
|
// Unless is admin,
|
||||||
|
// - Check for the kick permission.
|
||||||
|
// - Make sure the player is in the faction.
|
||||||
|
// - Make sure the kicked player has lower rank than the kicker.
|
||||||
|
if (!fme.isAdminBypassing()) {
|
||||||
Access access = myFaction.getAccess(fme, PermissableAction.KICK);
|
Access access = myFaction.getAccess(fme, PermissableAction.KICK);
|
||||||
if (access == Access.DENY || (access == Access.UNDEFINED && !assertMinRole(Role.MODERATOR))) {
|
if (access != Access.ALLOW && fme.getRole() != Role.ADMIN) {
|
||||||
fme.msg(TL.GENERIC_NOPERMISSION, "kick");
|
fme.msg(TL.GENERIC_NOPERMISSION, "kick");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (toKickFaction != myFaction) {
|
if (toKickFaction != myFaction) {
|
||||||
msg(TL.COMMAND_KICK_NOTMEMBER, toKick.describeTo(fme, true), myFaction.describeTo(fme));
|
msg(TL.COMMAND_KICK_NOTMEMBER, toKick.describeTo(fme, true), myFaction.describeTo(fme));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (toKick.getRole().value >= fme.getRole().value) {
|
||||||
// Check for Access before we check for Role.
|
|
||||||
if (access != Access.ALLOW && toKick.getRole().value >= fme.getRole().value) {
|
|
||||||
msg(TL.COMMAND_KICK_INSUFFICIENTRANK);
|
msg(TL.COMMAND_KICK_INSUFFICIENTRANK);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Conf.canLeaveWithNegativePower && toKick.getPower() < 0) {
|
if (!Conf.canLeaveWithNegativePower && toKick.getPower() < 0) {
|
||||||
msg(TL.COMMAND_KICK_NEGATIVEPOWER);
|
msg(TL.COMMAND_KICK_NEGATIVEPOWER);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Access access = myFaction.getAccess(fme, PermissableAction.KICK);
|
|
||||||
// This statement allows us to check if they've specifically denied it, or default to
|
|
||||||
// the old setting of allowing moderators to kick
|
|
||||||
if (access == Access.DENY || (access == Access.UNDEFINED && !assertMinRole(Role.MODERATOR))) {
|
|
||||||
fme.msg(TL.GENERIC_NOPERMISSION, "kick");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// if economy is enabled, they're not on the bypass list, and this command has a cost set, make sure they can pay
|
// if economy is enabled, they're not on the bypass list, and this command has a cost set, make sure they can pay
|
||||||
if (!canAffordCommand(Conf.econCostKick, TL.COMMAND_KICK_TOKICK.toString())) {
|
if (!canAffordCommand(Conf.econCostKick, TL.COMMAND_KICK_TOKICK.toString())) {
|
||||||
return;
|
return;
|
||||||
|
@ -329,6 +329,7 @@ public enum TL {
|
|||||||
COMMAND_INVITE_INVITEDYOU("&chas invited you to join "),
|
COMMAND_INVITE_INVITEDYOU("&chas invited you to join "),
|
||||||
COMMAND_INVITE_INVITED("&c&l[!]&7 &c%1$s&7 invited &c%2$s&7 to your faction."),
|
COMMAND_INVITE_INVITED("&c&l[!]&7 &c%1$s&7 invited &c%2$s&7 to your faction."),
|
||||||
COMMAND_INVITE_ALREADYMEMBER("&c&l[!]&7 &c%1$s&7 is already a member of&c %2$s"),
|
COMMAND_INVITE_ALREADYMEMBER("&c&l[!]&7 &c%1$s&7 is already a member of&c %2$s"),
|
||||||
|
COMMAND_INVITE_ALREADYINVITED("&c&l[!]&7 &c%1$s&7 has already been invited"),
|
||||||
COMMAND_INVITE_DESCRIPTION("Invite a player to your faction"),
|
COMMAND_INVITE_DESCRIPTION("Invite a player to your faction"),
|
||||||
COMMAND_INVITE_BANNED("&c&l[!]&7 &7%1$s &cis banned &7from your Faction. &cNot &7sending an invite."),
|
COMMAND_INVITE_BANNED("&c&l[!]&7 &7%1$s &cis banned &7from your Faction. &cNot &7sending an invite."),
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user