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 (
|
2024-12-26 17:54:42 -08:00
|
|
|
// has ScriptWrite
|
2024-12-28 22:08:28 -08:00
|
|
|
RoleQuat int32 = 255
|
2024-12-10 18:23:23 -08:00
|
|
|
// has SubmissionPublish
|
2024-12-28 22:08:28 -08:00
|
|
|
RoleMapAdmin int32 = 128
|
2024-12-10 18:23:23 -08:00
|
|
|
// has SubmissionReview
|
2024-12-28 22:08:28 -08:00
|
|
|
RoleMapCouncil int32 = 64
|
2024-11-29 13:58:47 -08:00
|
|
|
)
|
|
|
|
|
2024-12-28 22:08:28 -08:00
|
|
|
type Roles struct {
|
|
|
|
// human roles
|
|
|
|
SubmissionRelease bool
|
|
|
|
SubmissionReview bool
|
|
|
|
ScriptWrite bool
|
|
|
|
// Thumbnail bool
|
|
|
|
// MapDownload
|
2024-12-14 12:01:34 -08:00
|
|
|
|
2024-12-28 22:08:28 -08:00
|
|
|
// automated roles
|
|
|
|
Maptest bool
|
2024-11-29 13:58:47 -08:00
|
|
|
}
|
|
|
|
|
2024-12-28 22:08:28 -08:00
|
|
|
type UserInfo struct {
|
|
|
|
Roles Roles
|
|
|
|
UserID uint64
|
2024-11-29 13:58:47 -08:00
|
|
|
}
|
|
|
|
|
2024-12-28 22:08:28 -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
|
|
|
|
}
|
|
|
|
|
2024-12-28 22:08:28 -08:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2024-12-28 22:08:28 -08:00
|
|
|
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{
|
2024-12-28 22:08:28 -08:00
|
|
|
Roles: roles,
|
|
|
|
UserID: session.UserID,
|
2024-11-29 13:58:47 -08:00
|
|
|
})
|
|
|
|
|
|
|
|
return newCtx, nil
|
|
|
|
}
|