mirror of https://github.com/grafana/grafana
Extract search users functions into a service (#39002)
* Extract search users to a new service * Fix wire provider * Fix common_test and remove RouteRegister * Remove old endpoints * Fix test * Add indexes to dashboards and orgs tables * Fix lintpull/39774/head
parent
0ecf13e5a3
commit
02702eb82d
@ -0,0 +1,95 @@ |
|||||||
|
package searchusers |
||||||
|
|
||||||
|
import ( |
||||||
|
"github.com/grafana/grafana/pkg/api/dtos" |
||||||
|
"github.com/grafana/grafana/pkg/api/response" |
||||||
|
"github.com/grafana/grafana/pkg/bus" |
||||||
|
"github.com/grafana/grafana/pkg/models" |
||||||
|
) |
||||||
|
|
||||||
|
type Service interface { |
||||||
|
SearchUsers(c *models.ReqContext) response.Response |
||||||
|
SearchUsersWithPaging(c *models.ReqContext) response.Response |
||||||
|
} |
||||||
|
|
||||||
|
type OSSService struct { |
||||||
|
bus bus.Bus |
||||||
|
} |
||||||
|
|
||||||
|
func ProvideUsersService(bus bus.Bus) *OSSService { |
||||||
|
return &OSSService{bus: bus} |
||||||
|
} |
||||||
|
|
||||||
|
func (s *OSSService) SearchUsers(c *models.ReqContext) response.Response { |
||||||
|
query, err := s.SearchUser(c) |
||||||
|
if err != nil { |
||||||
|
return response.Error(500, "Failed to fetch users", err) |
||||||
|
} |
||||||
|
|
||||||
|
return response.JSON(200, query.Result.Users) |
||||||
|
} |
||||||
|
|
||||||
|
func (s *OSSService) SearchUsersWithPaging(c *models.ReqContext) response.Response { |
||||||
|
query, err := s.SearchUser(c) |
||||||
|
if err != nil { |
||||||
|
return response.Error(500, "Failed to fetch users", err) |
||||||
|
} |
||||||
|
|
||||||
|
return response.JSON(200, query.Result) |
||||||
|
} |
||||||
|
|
||||||
|
func (s *OSSService) SearchUser(c *models.ReqContext) (*models.SearchUsersQuery, error) { |
||||||
|
perPage := c.QueryInt("perpage") |
||||||
|
if perPage <= 0 { |
||||||
|
perPage = 1000 |
||||||
|
} |
||||||
|
page := c.QueryInt("page") |
||||||
|
|
||||||
|
if page < 1 { |
||||||
|
page = 1 |
||||||
|
} |
||||||
|
|
||||||
|
searchQuery := c.Query("query") |
||||||
|
filter := c.Query("filter") |
||||||
|
|
||||||
|
query := &models.SearchUsersQuery{Query: searchQuery, Filter: models.SearchUsersFilter(filter), Page: page, Limit: perPage} |
||||||
|
if err := s.bus.Dispatch(query); err != nil { |
||||||
|
return nil, err |
||||||
|
} |
||||||
|
|
||||||
|
for _, user := range query.Result.Users { |
||||||
|
user.AvatarUrl = dtos.GetGravatarUrl(user.Email) |
||||||
|
user.AuthLabels = make([]string, 0) |
||||||
|
if user.AuthModule != nil && len(user.AuthModule) > 0 { |
||||||
|
for _, authModule := range user.AuthModule { |
||||||
|
user.AuthLabels = append(user.AuthLabels, GetAuthProviderLabel(authModule)) |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
query.Result.Page = page |
||||||
|
query.Result.PerPage = perPage |
||||||
|
|
||||||
|
return query, nil |
||||||
|
} |
||||||
|
|
||||||
|
func GetAuthProviderLabel(authModule string) string { |
||||||
|
switch authModule { |
||||||
|
case "oauth_github": |
||||||
|
return "GitHub" |
||||||
|
case "oauth_google": |
||||||
|
return "Google" |
||||||
|
case "oauth_azuread": |
||||||
|
return "AzureAD" |
||||||
|
case "oauth_gitlab": |
||||||
|
return "GitLab" |
||||||
|
case "oauth_grafana_com", "oauth_grafananet": |
||||||
|
return "grafana.com" |
||||||
|
case "auth.saml": |
||||||
|
return "SAML" |
||||||
|
case "ldap", "": |
||||||
|
return "LDAP" |
||||||
|
default: |
||||||
|
return "OAuth" |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue