diff --git a/internal/api/handlers_users.go b/internal/api/handlers_users.go index 8beaee9..549e213 100644 --- a/internal/api/handlers_users.go +++ b/internal/api/handlers_users.go @@ -18,13 +18,13 @@ func newUsersHandler(svc *service.TeamService) *usersHandler { // Search handles GET /v1/users/search?email= // Returns up to 10 users whose email starts with the given prefix. -// The prefix must contain "@" to scope searches and prevent broad enumeration. +// The prefix must be at least 3 characters long. func (h *usersHandler) Search(w http.ResponseWriter, r *http.Request) { auth.MustFromContext(r.Context()) // ensure authenticated prefix := strings.TrimSpace(r.URL.Query().Get("email")) - if !strings.Contains(prefix, "@") { - writeError(w, http.StatusBadRequest, "invalid_request", "email prefix must contain '@'") + if len(prefix) < 3 { + writeError(w, http.StatusBadRequest, "invalid_request", "email prefix must be at least 3 characters") return }