drone/internal/api/controller/user/list.go
Johannes Batzill fad6e18898 Introduce Controller for Repo, Space, User, and ServiceAccount (#25)
Preparing the support for harness specific API router + http handler, which allows us to have complete control over the rest api naming and functionality, without having to do complex path rewrites or request / reponse rewrites inline.
2022-10-03 18:56:49 -07:00

43 lines
1.2 KiB
Go

// Copyright 2021 Harness Inc. All rights reserved.
// Use of this source code is governed by the Polyform Free Trial License
// that can be found in the LICENSE.md file for this repository.
package user
import (
"context"
"fmt"
apiauth "github.com/harness/gitness/internal/api/auth"
"github.com/harness/gitness/internal/auth"
"github.com/harness/gitness/types"
"github.com/harness/gitness/types/enum"
)
/*
* List lists all users of the system.
*/
func (c *Controller) List(ctx context.Context, session *auth.Session,
userFilter *types.UserFilter) (int64, []*types.User, error) {
// Ensure principal has required permissions (user is global, no explicit resource)
scope := &types.Scope{}
resource := &types.Resource{
Type: enum.ResourceTypeUser,
}
if err := apiauth.Check(ctx, c.authorizer, session, scope, resource, enum.PermissionUserView); err != nil {
return 0, nil, err
}
count, err := c.userStore.Count(ctx)
if err != nil {
return 0, nil, fmt.Errorf("failed to count users: %w", err)
}
repos, err := c.userStore.List(ctx, userFilter)
if err != nil {
return 0, nil, fmt.Errorf("failed to list users: %w", err)
}
return count, repos, nil
}