feat (user): use case done

This commit is contained in:
dpurbosakti
2025-08-18 13:02:14 +07:00
parent db6af776a3
commit 0c5aa0becf
6 changed files with 181 additions and 13 deletions
+3 -3
View File
@@ -32,7 +32,7 @@ type Deletedto struct {
}
type MetaDto struct {
PageNumber int `json:"page_number"`
PageSize int `json:"page_size"`
Count int64 `json:"count"`
PageNumber int `json:"page_number"`
PageSize int `json:"page_size"`
Count int `json:"count"`
}
@@ -26,7 +26,7 @@ var readListPreMw []readListMw // ..
var readListPostMw []readListMw // ..
var readDetailPreMw []readDetailMw
var readDetailPostMw []readDetailMw
var udpatePreMw []readDetailMw
var udpatePostMw []readDetailMw
var updatePreMw []readDetailMw
var updatePostMw []readDetailMw
var deletePreMw []readDetailMw
var deletePostMw []readDetailMw
+165 -1
View File
@@ -3,6 +3,7 @@ package user
import (
"fmt"
e "simrs-vx/internal/domain/main-entities/user"
"strconv"
dg "github.com/karincake/apem/db-gorm-pg"
d "github.com/karincake/dodol"
@@ -17,7 +18,7 @@ const source = "user"
func Create(input e.CreateDto) (*d.Data, error) {
data := e.User{}
setData(input, &data)
setCreate(input, &data)
event := pl.Event{
Feature: "Create",
@@ -104,3 +105,166 @@ func Create(input e.CreateDto) (*d.Data, error) {
Data: data,
}, nil
}
func ReadList(input e.ReadListDto) (*d.Data, error) {
var data *e.User
var dataList []e.User
var metaList *e.MetaDto
var err error
err = dg.I.Transaction(func(tx *gorm.DB) error {
for i := range readListPreMw {
if err := readListPreMw[i](&input, data, tx); err != nil {
return nil
}
}
dataList, metaList, err = ReadListData(input, tx)
if err != nil {
return err
}
for i := range readListPostMw {
if err := readListPostMw[i](&input, data, tx); err != nil {
return nil
}
}
return nil
})
if err != nil {
return nil, err
}
return &d.Data{
Meta: d.IS{
"source": source,
"structure": "list-data",
"status": "fetched",
"page_number": strconv.Itoa(metaList.PageNumber),
"page_size": strconv.Itoa(metaList.PageSize),
"record_totalCount": strconv.Itoa(metaList.Count),
},
Data: dataList,
}, nil
}
func ReadDetail(input e.ReadDetailDto) (*d.Data, error) {
var data *e.User
var err error
err = dg.I.Transaction(func(tx *gorm.DB) error {
for i := range readDetailPreMw {
if err := readDetailPreMw[i](&input, data, tx); err != nil {
return nil
}
}
data, err := ReadDetailData(input, tx)
if err != nil {
return err
}
for i := range readDetailPostMw {
if err := readDetailPostMw[i](&input, data, tx); err != nil {
return nil
}
}
return nil
})
if err != nil {
return nil, err
}
return &d.Data{
Meta: d.IS{
"source": source,
"structure": "single-data",
"status": "fetched",
},
Data: data,
}, nil
}
func Update(input e.Updatedto) (*d.Data, error) {
rdDto := e.ReadDetailDto{Id: input.Id}
var data *e.User
var err error
err = dg.I.Transaction(func(tx *gorm.DB) error {
data, err = ReadDetailData(rdDto, tx)
if err != nil {
return nil
}
err = setUpdate(input, data)
if err != nil {
return err
}
for i := range updatePreMw {
if err := updatePreMw[i](&rdDto, data, tx); err != nil {
return nil
}
}
if err := UpdateData(*data, tx); err != nil {
return nil
}
for i := range updatePostMw {
if err := updatePostMw[i](&rdDto, data, tx); err != nil {
return nil
}
}
return nil
})
if err != nil {
return nil, err
}
return &d.Data{
Meta: d.IS{
"source": source,
"structure": "single-data",
"status": "updated",
},
Data: data,
}, nil
}
func Delete(input e.Deletedto) (*d.Data, error) {
rdDto := e.ReadDetailDto{Id: input.Id}
var data *e.User
var err error
err = dg.I.Transaction(func(tx *gorm.DB) error {
data, err = ReadDetailData(rdDto, tx)
if err != nil {
return nil
}
for i := range deletePreMw {
if err := deletePreMw[i](&rdDto, data, tx); err != nil {
return nil
}
}
if err := DeleteData(data, tx); err != nil {
return nil
}
for i := range deletePostMw {
if err := deletePostMw[i](&rdDto, data, tx); err != nil {
return nil
}
}
return nil
})
if err != nil {
return nil, err
}
return &d.Data{
Meta: d.IS{
"source": source,
"structure": "single-data",
"status": "deleted",
},
Data: data,
}, nil
}
@@ -10,7 +10,7 @@ import (
p "simrs-vx/pkg/password"
)
func setData(src e.CreateDto, dst *e.User) error {
func setCreate(src e.CreateDto, dst *e.User) error {
pass, err := p.Hash(src.Password)
if err != nil {
return err
@@ -22,3 +22,10 @@ func setData(src e.CreateDto, dst *e.User) error {
return nil
}
func setUpdate(src e.Updatedto, dst *e.User) error {
dst.Name = src.CreateDto.Name
dst.Status_Code = src.CreateDto.Status_Code
return nil
}
+1 -4
View File
@@ -52,7 +52,7 @@ func ReadListData(input e.ReadListDto, dbx ...*gorm.DB) ([]e.User, *e.MetaDto, e
return nil, nil, err
}
meta.Count = count
meta.Count = int(count)
meta.PageNumber = pagination.PageNumber
meta.PageSize = pagination.PageSize
return data, &meta, nil
@@ -69,9 +69,6 @@ func ReadDetailData(input e.ReadDetailDto, dbx ...*gorm.DB) (*e.User, error) {
}
if err := tx.First(&data, input.Id).Error; err != nil {
if err == gorm.ErrRecordNotFound {
return nil, nil
}
return nil, err
}
@@ -26,7 +26,7 @@ var readListPreMw []readListMw // ..
var readListPostMw []readListMw // ..
var readDetailPreMw []readDetailMw
var readDetailPostMw []readDetailMw
var udpatePreMw []readDetailMw
var udpatePostMw []readDetailMw
var updatePreMw []readDetailMw
var updatePostMw []readDetailMw
var deletePreMw []readDetailMw
var deletePostMw []readDetailMw