Skip to content

Commit

Permalink
Implement logout endpoint for operator-ui (#1144)
Browse files Browse the repository at this point in the history
Signed-off-by: Lenin Alevski <alevsk.8772@gmail.com>
  • Loading branch information
Alevsk committed Oct 25, 2021
1 parent d1e4ce2 commit 972ea65
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 2 deletions.
3 changes: 2 additions & 1 deletion operatorapi/configure_operator.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,8 @@ func configureAPI(api *operations.OperatorAPI) http.Handler {
AccountAccessKey: claims.AccountAccessKey,
}, nil
}

// Register logout handlers
registerLogoutHandlers(api)
// Register login handlers
registerLoginHandlers(api)
registerSessionHandlers(api)
Expand Down
42 changes: 42 additions & 0 deletions operatorapi/operator_logout.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
// This file is part of MinIO Console Server
// Copyright (c) 2021 MinIO, Inc.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.

package operatorapi

import (
"net/http"

"github.com/go-openapi/runtime"
"github.com/go-openapi/runtime/middleware"
"github.com/minio/console/models"
"github.com/minio/console/operatorapi/operations"
"github.com/minio/console/operatorapi/operations/user_api"
"github.com/minio/console/restapi"
)

func registerLogoutHandlers(api *operations.OperatorAPI) {
// logout from console
api.UserAPILogoutHandler = user_api.LogoutHandlerFunc(func(params user_api.LogoutParams, session *models.Principal) middleware.Responder {
// Custom response writer to expire the session cookies
return middleware.ResponderFunc(func(w http.ResponseWriter, p runtime.Producer) {
expiredCookie := restapi.ExpireSessionCookie()
// this will tell the browser to clear the cookie and invalidate user session
// additionally we are deleting the cookie from the client side
http.SetCookie(w, &expiredCookie)
user_api.NewLogoutOK().WriteResponse(w, p)
})
})
}
2 changes: 1 addition & 1 deletion swagger-console.yml
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ paths:

/logout:
post:
summary: Logout from Console.
summary: Logout from Operator.
operationId: Logout
responses:
200:
Expand Down

0 comments on commit 972ea65

Please sign in to comment.