mirror of
https://github.com/harness/drone.git
synced 2025-05-04 19:39:16 +08:00

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.
38 lines
1.0 KiB
Go
38 lines
1.0 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 space
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/harness/gitness/internal/api/controller/space"
|
|
"github.com/harness/gitness/internal/api/render"
|
|
"github.com/harness/gitness/internal/api/request"
|
|
)
|
|
|
|
/*
|
|
* Writes json-encoded service account information to the http response body.
|
|
*/
|
|
func HandleListServiceAccounts(spaceCtrl *space.Controller) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
ctx := r.Context()
|
|
session, _ := request.AuthSessionFrom(ctx)
|
|
spaceRef, err := request.GetSpaceRef(r)
|
|
if err != nil {
|
|
render.TranslatedUserError(w, err)
|
|
return
|
|
}
|
|
|
|
sas, err := spaceCtrl.ListServiceAccounts(ctx, session, spaceRef)
|
|
if err != nil {
|
|
render.TranslatedUserError(w, err)
|
|
return
|
|
}
|
|
|
|
// TODO: do we need pagination? we should block that many service accounts in the first place.
|
|
render.JSON(w, http.StatusOK, sas)
|
|
}
|
|
}
|