Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var Command = &commands.YAGCommand{ CmdCategory: commands.CategoryTool, Name: "ListRoles", Aliases: []string{"lr", "ur"}, Description: "List roles, their id's, color hex code, and 'mention everyone' perms (useful if you wanna double check to make sure you didn't give anyone mention everyone perms that shouldn't have it)", Arguments: []*dcmd.ArgDef{ {Name: "User", Type: &commands.MemberArg{}}, }, ArgSwitches: []*dcmd.ArgDef{ {Switch: "nomanaged", Name: "Don't list managed/bot roles"}, }, RunFunc: func(data *dcmd.Data) (interface{}, error) { var out, outFinal string var noMana bool var member *dstate.MemberState if data.Args[0].Value != nil { member = data.Args[0].Value.(*dstate.MemberState) } if data.Switches["nomanaged"].Value != nil && data.Switches["nomanaged"].Value.(bool) && member == nil { noMana = true } data.GS.Lock() defer data.GS.Unlock() sort.Sort(dutil.Roles(data.GS.Guild.Roles)) counter := 0 if member != nil { if len(member.Roles) > 0 { for _, roleID := range member.Roles { for _, r := range data.GS.Guild.Roles { if roleID == r.ID { counter++ me := r.Permissions&discordgo.PermissionAdministrator != 0 || r.Permissions&discordgo.PermissionMentionEveryone != 0 out += fmt.Sprintf("`%-25s: %-19d #%-6x ME:%5t`\n", r.Name, r.ID, r.Color, me) } } } } else { return "User has no roles", nil } } else { for _, r := range data.GS.Guild.Roles { if noMana && r.Managed { continue } else { counter++ me := r.Permissions&discordgo.PermissionAdministrator != 0 || r.Permissions&discordgo.PermissionMentionEveryone != 0 out += fmt.Sprintf("`%-25s: %-19d #%-6x ME:%5t`\n", r.Name, r.ID, r.Color, me) } } } outFinal = fmt.Sprintf("Total role count: %d\n", counter) outFinal += fmt.Sprintf("%s", "(ME = mention everyone perms)\n") outFinal += out return outFinal, nil }, }
Functions ¶
This section is empty.
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.