feat (user): use case done
This commit is contained in:
@@ -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
|
||||
|
||||
@@ -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
|
||||
}
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user