// 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 ( "errors" "net/http" "github.com/harness/gitness/internal/api/render" "github.com/harness/gitness/internal/api/request" "github.com/harness/gitness/internal/store" "github.com/harness/gitness/types/enum" "github.com/rs/zerolog/hlog" ) // HandleDeletePAT returns an http.HandlerFunc that // deletes a PAT token of a user. func HandleDeletePAT(tokenStore store.TokenStore) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { log := hlog.FromRequest(r) ctx := r.Context() user, _ := request.UserFrom(ctx) patID, err := request.GetPatID(r) if err != nil { render.BadRequest(w) return } token, err := tokenStore.Find(ctx, patID) if errors.Is(err, store.ErrResourceNotFound) { render.UserfiedErrorOrInternal(w, err) return } // Ensure pat belongs to the user! if token.Type != enum.TokenTypePAT || token.PrincipalID != user.ID { log.Warn().Msg("User tried to delete token that doesn't belong to itself or is no PAT") // render not found - no need for user to know other token ids. render.NotFound(w) return } err = tokenStore.Delete(ctx, patID) if err != nil { log.Err(err).Msg("failed to delete PAT") render.UserfiedErrorOrInternal(w, err) return } w.WriteHeader(http.StatusNoContent) } }