maps-service/pkg/service/security.go

103 lines
2.0 KiB
Go
Raw Normal View History

2024-11-29 13:58:47 -08:00
package service
import (
"context"
2024-12-12 17:29:20 -05:00
"errors"
2024-11-29 13:58:47 -08:00
"git.itzana.me/strafesnet/go-grpc/auth"
2024-12-12 17:29:20 -05:00
"git.itzana.me/strafesnet/maps-service/pkg/api"
2024-11-29 13:58:47 -08:00
)
var (
// ErrMissingSessionID there is no session id
ErrMissingSessionID = errors.New("SessionID missing")
// ErrInvalidSession caller does not have a valid session
ErrInvalidSession = errors.New("Session invalid")
)
var (
// has ScriptWrite
RoleQuat int32 = 255
2024-12-10 18:23:23 -08:00
// has SubmissionPublish
RoleMapAdmin int32 = 128
2024-12-10 18:23:23 -08:00
// has SubmissionReview
RoleMapCouncil int32 = 64
2024-11-29 13:58:47 -08:00
)
type Roles struct {
// human roles
SubmissionRelease bool
SubmissionReview bool
ScriptWrite bool
// Thumbnail bool
// MapDownload
2024-12-14 12:01:34 -08:00
// automated roles
Maptest bool
2024-11-29 13:58:47 -08:00
}
type UserInfo struct {
Roles Roles
UserID uint64
2024-11-29 13:58:47 -08:00
}
func (usr UserInfo) IsSubmitter(submitter uint64) bool {
return usr.UserID == submitter
2024-11-29 13:58:47 -08:00
}
type SecurityHandler struct {
2024-12-09 20:10:23 -08:00
Client auth.AuthServiceClient
2024-11-29 13:58:47 -08:00
}
2024-12-12 17:29:20 -05:00
func (svc SecurityHandler) HandleCookieAuth(ctx context.Context, operationName api.OperationName, t api.CookieAuth) (context.Context, error) {
2024-11-29 13:58:47 -08:00
sessionId := t.GetAPIKey()
if sessionId == "" {
return nil, ErrMissingSessionID
}
session, err := svc.Client.GetSessionUser(ctx, &auth.IdMessage{
SessionID: sessionId,
})
if err != nil {
return nil, err
}
role, err := svc.Client.GetGroupRole(ctx, &auth.IdMessage{
SessionID: sessionId,
})
if err != nil {
return nil, err
}
2024-12-09 20:10:23 -08:00
validate, err := svc.Client.ValidateSession(ctx, &auth.IdMessage{
2024-11-29 13:58:47 -08:00
SessionID: sessionId,
})
2024-12-12 17:29:20 -05:00
if err != nil {
2024-11-29 13:58:47 -08:00
return nil, err
}
2024-12-12 17:29:20 -05:00
if !validate.Valid {
2024-11-29 13:58:47 -08:00
return nil, ErrInvalidSession
}
roles := Roles{}
// fix this when roblox udpates group roles
for _, r := range role.Roles {
if RoleQuat <= r.Rank {
roles.ScriptWrite = true
}
if RoleMapAdmin <= r.Rank {
roles.SubmissionRelease = true
}
if RoleMapCouncil <= r.Rank {
roles.SubmissionReview = true
}
}
2024-11-29 13:58:47 -08:00
newCtx := context.WithValue(ctx, "UserInfo", UserInfo{
Roles: roles,
UserID: session.UserID,
2024-11-29 13:58:47 -08:00
})
return newCtx, nil
}