medol-be/app/module/activity_logs/service/activity_logs.service.go

132 lines
4.3 KiB
Go
Raw Permalink Normal View History

2025-02-07 04:07:13 +00:00
package service
import (
2025-07-02 06:03:52 +00:00
"github.com/google/uuid"
2025-02-07 04:07:13 +00:00
"github.com/rs/zerolog"
2025-07-02 06:03:52 +00:00
"web-medols-be/app/database/entity"
"web-medols-be/app/module/activity_logs/mapper"
"web-medols-be/app/module/activity_logs/repository"
"web-medols-be/app/module/activity_logs/request"
"web-medols-be/app/module/activity_logs/response"
"web-medols-be/app/module/articles/service"
usersRepository "web-medols-be/app/module/users/repository"
"web-medols-be/utils/paginator"
utilSvc "web-medols-be/utils/service"
2025-02-07 04:07:13 +00:00
)
// ActivityLogsService
type activityLogsService struct {
2025-02-15 01:56:13 +00:00
Repo repository.ActivityLogsRepository
UsersRepo usersRepository.UsersRepository
ArticleService service.ArticlesService
Log zerolog.Logger
2025-02-07 04:07:13 +00:00
}
// ActivityLogsService define interface of IActivityLogsService
type ActivityLogsService interface {
2025-07-02 06:03:52 +00:00
All(clientId *uuid.UUID, req request.ActivityLogsQueryRequest) (activityLogs []*response.ActivityLogsResponse, paging paginator.Pagination, err error)
Show(clientId *uuid.UUID, id uint) (activityLogs *response.ActivityLogsResponse, err error)
Save(clientId *uuid.UUID, req request.ActivityLogsCreateRequest, authToken *string) (activityLogs *entity.ActivityLogs, err error)
Update(clientId *uuid.UUID, id uint, req request.ActivityLogsUpdateRequest) (err error)
Delete(clientId *uuid.UUID, id uint) error
GetActivityStats(clientId *uuid.UUID) (activityStats *response.ActivityStatsResponse, err error)
2025-02-07 04:07:13 +00:00
}
// NewActivityLogsService init ActivityLogsService
2025-02-15 01:56:13 +00:00
func NewActivityLogsService(repo repository.ActivityLogsRepository, log zerolog.Logger, usersRepo usersRepository.UsersRepository, articleService service.ArticlesService) ActivityLogsService {
2025-02-07 04:07:13 +00:00
return &activityLogsService{
2025-02-15 01:56:13 +00:00
Repo: repo,
Log: log,
UsersRepo: usersRepo,
ArticleService: articleService,
2025-02-07 04:07:13 +00:00
}
}
// All implement interface of ActivityLogsService
2025-07-02 06:03:52 +00:00
func (_i *activityLogsService) All(clientId *uuid.UUID, req request.ActivityLogsQueryRequest) (activityLogss []*response.ActivityLogsResponse, paging paginator.Pagination, err error) {
results, paging, err := _i.Repo.GetAll(clientId, req)
2025-02-07 04:07:13 +00:00
if err != nil {
return
}
for _, result := range results {
activityLogss = append(activityLogss, mapper.ActivityLogsResponseMapper(result))
}
return
}
2025-07-02 06:03:52 +00:00
func (_i *activityLogsService) Show(clientId *uuid.UUID, id uint) (activityLogs *response.ActivityLogsResponse, err error) {
result, err := _i.Repo.FindOne(clientId, id)
2025-02-07 04:07:13 +00:00
if err != nil {
return nil, err
}
return mapper.ActivityLogsResponseMapper(result), nil
}
2025-07-02 06:03:52 +00:00
func (_i *activityLogsService) Save(clientId *uuid.UUID, req request.ActivityLogsCreateRequest, authToken *string) (activityLogs *entity.ActivityLogs, err error) {
2025-02-07 04:07:13 +00:00
_i.Log.Info().Interface("data", req).Msg("")
newReq := req.ToEntity()
2025-07-02 06:03:52 +00:00
if clientId != nil {
newReq.ClientId = clientId
}
2025-02-07 04:07:13 +00:00
if authToken != nil {
createdBy := utilSvc.GetUserInfo(_i.Log, _i.UsersRepo, *authToken)
newReq.UserId = &createdBy.ID
}
2025-02-15 01:56:13 +00:00
result, err := _i.Repo.Create(newReq)
if err != nil {
return nil, err
}
// update article
2025-07-02 06:03:52 +00:00
err = _i.ArticleService.UpdateActivityCount(clientId, *req.ArticleId, req.ActivityTypeId)
2025-02-15 01:56:13 +00:00
if err != nil {
return nil, err
}
return result, nil
2025-02-07 04:07:13 +00:00
}
2025-07-02 06:03:52 +00:00
func (_i *activityLogsService) Update(clientId *uuid.UUID, id uint, req request.ActivityLogsUpdateRequest) (err error) {
2025-02-07 04:07:13 +00:00
_i.Log.Info().Interface("data", req).Msg("")
2025-07-02 06:03:52 +00:00
newReq := req.ToEntity()
if clientId != nil {
newReq.ClientId = clientId
}
return _i.Repo.Update(clientId, id, newReq)
2025-02-07 04:07:13 +00:00
}
2025-07-02 06:03:52 +00:00
func (_i *activityLogsService) Delete(clientId *uuid.UUID, id uint) error {
return _i.Repo.Delete(clientId, id)
2025-02-07 04:07:13 +00:00
}
2025-07-02 06:03:52 +00:00
func (_i *activityLogsService) GetActivityStats(clientId *uuid.UUID) (activityStats *response.ActivityStatsResponse, err error) {
_i.Log.Info().Interface("GetActivityStats", "checker").Msg("")
2025-07-02 06:03:52 +00:00
countUniqueVisitorAllTime, err := _i.Repo.CountUniqueVisitorAllTime(clientId)
if err != nil {
return nil, err
}
2025-07-02 06:03:52 +00:00
countUniqueVisitorToday, err := _i.Repo.CountUniqueVisitorToday(clientId)
if err != nil {
return nil, err
}
2025-07-02 06:03:52 +00:00
countTotalViewAllTime, err := _i.Repo.CountTotalViewAllTime(clientId)
if err != nil {
return nil, err
}
getActivityStats := &response.ActivityStatsResponse{
TotalVisitorAllTime: countUniqueVisitorAllTime,
TotalVisitorToday: countUniqueVisitorToday,
TotalViewAllTime: countTotalViewAllTime,
}
return getActivityStats, nil
}