Fix bug if caller or target don't have any roles
This commit is contained in:
parent
4729d2c5ee
commit
a10b5cdbec
10
utils.go
10
utils.go
@ -24,6 +24,10 @@ func GetDefaultStatusManager() StatusManager {
|
|||||||
|
|
||||||
// HasHigherRole checks if the caller has a higher role than the target in the given guild
|
// HasHigherRole checks if the caller has a higher role than the target in the given guild
|
||||||
func HasHigherRole(session *discordgo.Session, guildID string, callerID string, targetID string) bool {
|
func HasHigherRole(session *discordgo.Session, guildID string, callerID string, targetID string) bool {
|
||||||
|
guild, _ := session.Guild(guildID)
|
||||||
|
if callerID == guild.OwnerID {
|
||||||
|
return true // If the caller is the guild owner then they are automatically higher than everyone
|
||||||
|
}
|
||||||
caller, _ := session.GuildMember(guildID, callerID)
|
caller, _ := session.GuildMember(guildID, callerID)
|
||||||
target, _ := session.GuildMember(guildID, targetID)
|
target, _ := session.GuildMember(guildID, targetID)
|
||||||
var callerRoles []*discordgo.Role
|
var callerRoles []*discordgo.Role
|
||||||
@ -38,6 +42,12 @@ func HasHigherRole(session *discordgo.Session, guildID string, callerID string,
|
|||||||
targetRoles = append(targetRoles, role)
|
targetRoles = append(targetRoles, role)
|
||||||
}
|
}
|
||||||
sort.Slice(targetRoles, func(i, j int) bool { return targetRoles[i].Position > targetRoles[j].Position })
|
sort.Slice(targetRoles, func(i, j int) bool { return targetRoles[i].Position > targetRoles[j].Position })
|
||||||
|
if len(callerRoles) == 0 {
|
||||||
|
return false // If the caller doesn't have any roles then they can't be higher than the target
|
||||||
|
}
|
||||||
|
if len(callerRoles) > 0 && len(targetRoles) == 0 {
|
||||||
|
return true // If the caller has a role and the target doesn't then that role is higher
|
||||||
|
}
|
||||||
if callerRoles[0].Position > targetRoles[0].Position {
|
if callerRoles[0].Position > targetRoles[0].Position {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user