54 lines
1.1 KiB
Go
54 lines
1.1 KiB
Go
package auth
|
|
|
|
import (
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/gin-contrib/sessions"
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/google/uuid"
|
|
"gorm.io/gorm"
|
|
|
|
"dev.sum7.eu/genofire/golang-lib/web"
|
|
)
|
|
|
|
// GetCurrentUserID get UserID of session in golang-gin
|
|
func GetCurrentUserID(c *gin.Context) (uuid.UUID, bool) {
|
|
session := sessions.Default(c)
|
|
|
|
v := session.Get("user_id")
|
|
if v == nil {
|
|
c.JSON(http.StatusUnauthorized, web.HTTPError{
|
|
Message: APIErrorNoSession,
|
|
})
|
|
return uuid.Nil, false
|
|
}
|
|
|
|
id := uuid.MustParse(v.(string))
|
|
return id, true
|
|
}
|
|
|
|
// GetCurrentUser get User of session from database in golang-gin
|
|
func GetCurrentUser(c *gin.Context, ws *web.Service) (*User, bool) {
|
|
id, ok := GetCurrentUserID(c)
|
|
if !ok {
|
|
return nil, false
|
|
}
|
|
d := &User{ID: id}
|
|
if err := ws.DB.First(d).Error; err != nil {
|
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
c.JSON(http.StatusUnauthorized, web.HTTPError{
|
|
Message: APIErrorUserNotFound,
|
|
Error: err.Error(),
|
|
})
|
|
return nil, false
|
|
}
|
|
c.JSON(http.StatusInternalServerError, web.HTTPError{
|
|
Message: web.APIErrorInternalDatabase,
|
|
Error: err.Error(),
|
|
})
|
|
return nil, false
|
|
}
|
|
return d, true
|
|
}
|