This commit is contained in:
2026-02-11 17:46:22 +03:00
commit eacfacb13b
266 changed files with 51337 additions and 0 deletions

44
svc/auth/logout.go Normal file
View File

@@ -0,0 +1,44 @@
package auth
import (
"bssapp-backend/internal/auditlog"
"bssapp-backend/repository"
"database/sql"
"encoding/json"
"net/http"
"time"
)
func LogoutAllHandler(db *sql.DB) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
claims, ok := GetClaimsFromContext(r.Context())
if !ok || claims == nil {
http.Error(w, "Unauthorized", http.StatusUnauthorized)
return
}
userID := claims.ID
_ = repository.NewRefreshTokenRepository(db).
RevokeAllForUser(userID)
http.SetCookie(w, &http.Cookie{
Name: "mk_refresh",
Value: "",
Path: "/",
Expires: time.Unix(0, 0),
HttpOnly: true,
})
auditlog.Write(auditlog.ActivityLog{
UserID: auditlog.IntUserIDToUUID(int(userID)),
ActionType: "logout_all",
ActionCategory: "auth",
Description: "user logged out from all devices",
IsSuccess: true,
})
_ = json.NewEncoder(w).Encode(map[string]bool{"success": true})
}
}