split one service file to many
This commit is contained in:
parent
e17f68a7e5
commit
14bb2783c3
4 changed files with 282 additions and 273 deletions
115
internal/merch/service_merch.go
Normal file
115
internal/merch/service_merch.go
Normal file
|
|
@ -0,0 +1,115 @@
|
|||
package merch
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/google/uuid"
|
||||
)
|
||||
|
||||
func (s *service) createMerch(ctx context.Context, userId int64, payload *newMerchDTO) error {
|
||||
now := s.utils.TimeNowUTC()
|
||||
nullNow := s.utils.NullTimeFromNow(now)
|
||||
empty := s.utils.DeletedNullTime()
|
||||
|
||||
merchUuid, err := uuid.NewV7()
|
||||
if err != nil {
|
||||
logErr(serviceLogHeader, err)
|
||||
return err
|
||||
}
|
||||
|
||||
newMerch := &Merch{
|
||||
CreatedAt: now,
|
||||
UpdatedAt: nullNow,
|
||||
DeletedAt: empty,
|
||||
MerchUuid: merchUuid.String(),
|
||||
UserId: userId,
|
||||
Name: payload.Name,
|
||||
}
|
||||
|
||||
var merchExtra []ExtraData
|
||||
if payload.Links != nil {
|
||||
|
||||
originsMap, _, err := s.getOriginsMaps(ctx)
|
||||
if err != nil {
|
||||
logErr(serviceLogHeader, err)
|
||||
return err
|
||||
}
|
||||
|
||||
for _, item := range payload.Links {
|
||||
merchExtra = append(merchExtra, ExtraData{
|
||||
CreatedAt: now,
|
||||
UpdatedAt: nullNow,
|
||||
DeletedAt: empty,
|
||||
MerchId: 0,
|
||||
OriginId: originsMap[item.Origin],
|
||||
URL: item.Link,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
return s.repo.createMerch(ctx, newMerch, merchExtra)
|
||||
}
|
||||
|
||||
func (s *service) getMany(ctx context.Context, userId int64) ([]merchDTO, error) {
|
||||
return s.repo.getMany(ctx, userId)
|
||||
}
|
||||
|
||||
func (s *service) updateMerch(ctx context.Context, userId int64, payload *updateMerchDTO) (*merchDTO, error) {
|
||||
return s.repo.updateMerch(ctx, userId, payload)
|
||||
}
|
||||
|
||||
func (s *service) updateExtraData(ctx context.Context, userId int64, payload *extraDataDTO) (*extraDataDTO, error) {
|
||||
merchId, err := s.repo.getMerchIdByUuid(ctx, userId, payload.MerchUuid)
|
||||
if err != nil {
|
||||
logErr(serviceLogHeader, err)
|
||||
return nil, err
|
||||
}
|
||||
|
||||
origins, ids, err := s.getOriginsMaps(ctx)
|
||||
if err != nil {
|
||||
logErr(serviceLogHeader, err)
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var insertData []ExtraData
|
||||
for _, item := range payload.Links {
|
||||
if _, ok := origins[item.Origin]; !ok {
|
||||
continue
|
||||
}
|
||||
|
||||
now := s.utils.TimeNowUTC()
|
||||
|
||||
insertData = append(insertData, ExtraData{
|
||||
CreatedAt: now,
|
||||
UpdatedAt: s.utils.NullTimeFromNow(now),
|
||||
OriginId: origins[item.Origin],
|
||||
URL: item.Link,
|
||||
})
|
||||
}
|
||||
|
||||
result, err := s.repo.updateExtraData(ctx, merchId, insertData)
|
||||
if err != nil {
|
||||
logErr(serviceLogHeader, err)
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if result == nil || len(result) == 0 {
|
||||
return nil, nil
|
||||
}
|
||||
|
||||
var ol []originLink
|
||||
for _, item := range result {
|
||||
ol = append(ol, originLink{
|
||||
Origin: ids[item.OriginId],
|
||||
Link: item.URL,
|
||||
})
|
||||
}
|
||||
|
||||
return &extraDataDTO{
|
||||
MerchUuid: payload.MerchUuid,
|
||||
Links: ol,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (s *service) deleteOneMerchRecord(ctx context.Context, userId int64, merchUuid string) error {
|
||||
return s.repo.deleteOneMerchRecord(ctx, userId, merchUuid, s.utils.TimeNowUTC())
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue