mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
Ignore blank role names in getRolesByName call. (#8507)
This commit is contained in:
committed by
Jesús Espino
parent
5fa1b35819
commit
ca5198c7b6
10
api4/role.go
10
api4/role.go
@@ -5,6 +5,7 @@ package api4
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"strings"
|
||||
|
||||
"github.com/mattermost/mattermost-server/model"
|
||||
)
|
||||
@@ -52,14 +53,21 @@ func getRolesByNames(c *Context, w http.ResponseWriter, r *http.Request) {
|
||||
return
|
||||
}
|
||||
|
||||
var cleanedRoleNames []string
|
||||
for _, rolename := range rolenames {
|
||||
if strings.TrimSpace(rolename) == "" {
|
||||
continue
|
||||
}
|
||||
|
||||
if !model.IsValidRoleName(rolename) {
|
||||
c.SetInvalidParam("rolename")
|
||||
return
|
||||
}
|
||||
|
||||
cleanedRoleNames = append(cleanedRoleNames, rolename)
|
||||
}
|
||||
|
||||
if roles, err := c.App.GetRolesByNames(rolenames); err != nil {
|
||||
if roles, err := c.App.GetRolesByNames(cleanedRoleNames); err != nil {
|
||||
c.Err = err
|
||||
return
|
||||
} else {
|
||||
|
||||
@@ -129,13 +129,21 @@ func TestGetRolesByNames(t *testing.T) {
|
||||
assert.Contains(t, received, role2)
|
||||
assert.Contains(t, received, role3)
|
||||
|
||||
// Check a list of invalid roles.
|
||||
// TODO: Confirm whether no error for invalid role names is intended.
|
||||
// Check a list of non-existant roles.
|
||||
received, resp = th.Client.GetRolesByNames([]string{model.NewId(), model.NewId()})
|
||||
CheckNoError(t, resp)
|
||||
|
||||
// Empty list should error.
|
||||
_, resp = th.SystemAdminClient.GetRolesByNames([]string{})
|
||||
CheckBadRequestStatus(t, resp)
|
||||
|
||||
// Invalid role name should error.
|
||||
received, resp = th.Client.GetRolesByNames([]string{model.NewId(), model.NewId(), "!!!!!!"})
|
||||
CheckBadRequestStatus(t, resp)
|
||||
|
||||
// Empty/whitespace rolenames should be ignored.
|
||||
received, resp = th.Client.GetRolesByNames([]string{model.NewId(), model.NewId(), "", " "})
|
||||
CheckNoError(t, resp)
|
||||
}
|
||||
|
||||
func TestPatchRole(t *testing.T) {
|
||||
|
||||
Reference in New Issue
Block a user