ms-tester/internal/services/contest.go

58 lines
2 KiB
Go
Raw Permalink Normal View History

2024-08-16 16:50:47 +00:00
package services
import (
"context"
2024-08-23 09:56:52 +00:00
"git.sch9.ru/new_gate/ms-tester/internal/lib"
2024-08-25 16:52:00 +00:00
"git.sch9.ru/new_gate/ms-tester/pkg/models"
2024-08-16 16:50:47 +00:00
)
type ContestStorage interface {
CreateContest(ctx context.Context, contest *models.Contest) (int32, error)
ReadContestById(ctx context.Context, id int32) (*models.Contest, error)
UpdateContest(ctx context.Context, contest *models.Contest) error
DeleteContest(ctx context.Context, id int32) error
}
type ContestService struct {
2024-08-23 09:56:52 +00:00
contestStorage ContestStorage
permissionService IPermissionService
2024-08-16 16:50:47 +00:00
}
func NewContestService(
contestStorage ContestStorage,
2024-08-23 09:56:52 +00:00
permissionService IPermissionService,
2024-08-16 16:50:47 +00:00
) *ContestService {
return &ContestService{
2024-08-23 09:56:52 +00:00
contestStorage: contestStorage,
permissionService: permissionService,
2024-08-16 16:50:47 +00:00
}
}
func (service *ContestService) CreateContest(ctx context.Context, contest *models.Contest) (int32, error) {
2024-08-23 09:56:52 +00:00
if !service.permissionService.Allowed(ctx, extractUser(ctx), "create") {
return 0, lib.ServiceError(nil, lib.ErrNoPermission, "permission denied")
}
2024-08-16 16:50:47 +00:00
return service.contestStorage.CreateContest(ctx, contest)
}
2024-08-16 17:04:49 +00:00
func (service *ContestService) ReadContestById(ctx context.Context, id int32) (*models.Contest, error) {
2024-08-23 09:56:52 +00:00
if !service.permissionService.Allowed(ctx, extractUser(ctx), "read") {
return nil, lib.ServiceError(nil, lib.ErrNoPermission, "permission denied")
}
2024-08-16 17:04:49 +00:00
return service.contestStorage.ReadContestById(ctx, id)
2024-08-16 16:50:47 +00:00
}
2024-08-16 17:04:49 +00:00
func (service *ContestService) UpdateContest(ctx context.Context, contest *models.Contest) error {
2024-08-23 09:56:52 +00:00
if !service.permissionService.Allowed(ctx, extractUser(ctx), "update") {
return lib.ServiceError(nil, lib.ErrNoPermission, "permission denied")
}
2024-08-16 16:50:47 +00:00
return service.contestStorage.UpdateContest(ctx, contest)
}
2024-08-16 17:04:49 +00:00
func (service *ContestService) DeleteContest(ctx context.Context, id int32) error {
2024-08-23 09:56:52 +00:00
if !service.permissionService.Allowed(ctx, extractUser(ctx), "delete") {
return lib.ServiceError(nil, lib.ErrNoPermission, "permission denied")
}
2024-08-16 17:04:49 +00:00
return service.contestStorage.DeleteContest(ctx, id)
2024-08-16 16:50:47 +00:00
}