drone/internal/api/handler/account/logout.go
2023-09-07 00:58:23 +00:00

37 lines
1.2 KiB
Go

// Copyright 2022 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 account
import (
"net/http"
"github.com/harness/gitness/internal/api/controller/user"
"github.com/harness/gitness/internal/api/render"
"github.com/harness/gitness/internal/api/request"
)
// HandleLogout returns a http.HandlerFunc that deletes the
// user token being used in the respective request and logs the user out.
func HandleLogout(userCtrl *user.Controller) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
ctx := r.Context()
session, _ := request.AuthSessionFrom(ctx)
err := userCtrl.Logout(ctx, session)
// best effort delete cookie even in case of errors, to avoid clients being unable to remove the cookie.
// WARNING: It could be that the cookie is removed even though the token is still there in the DB.
// However, we have APIs to list and delete session tokens, and expiry time is usually short.
deleteTokenCookieIfPresent(r, w)
if err != nil {
render.TranslatedUserError(w, err)
return
}
render.DeleteSuccessful(w)
}
}