MatchCategory finds a category by name or slug (case-insensitive). It prefers an exact slug match over a name match, so users are encouraged to use slugs for unambiguous lookups.
(input string, categories []client.DiscussionCategory)
| 12 | // It prefers an exact slug match over a name match, so users are |
| 13 | // encouraged to use slugs for unambiguous lookups. |
| 14 | func MatchCategory(input string, categories []client.DiscussionCategory) (*client.DiscussionCategory, error) { |
| 15 | for i := range categories { |
| 16 | if strings.EqualFold(categories[i].Slug, input) { |
| 17 | return &categories[i], nil |
| 18 | } |
| 19 | } |
| 20 | for i := range categories { |
| 21 | if strings.EqualFold(categories[i].Name, input) { |
| 22 | return &categories[i], nil |
| 23 | } |
| 24 | } |
| 25 | |
| 26 | slugs := make([]string, len(categories)) |
| 27 | for i, c := range categories { |
| 28 | slugs[i] = c.Slug |
| 29 | } |
| 30 | slices.Sort(slugs) |
| 31 | return nil, fmt.Errorf("unknown category: %q; must be one of: %s", input, strings.Join(slugs, ", ")) |
| 32 | } |