295 lines
6.2 KiB
Go
295 lines
6.2 KiB
Go
package installation
|
|
|
|
import (
|
|
erc "simrs-vx/internal/domain/references/common"
|
|
"strconv"
|
|
"time"
|
|
|
|
dg "github.com/karincake/apem/db-gorm-pg"
|
|
d "github.com/karincake/dodol"
|
|
|
|
pl "simrs-vx/pkg/logger"
|
|
pu "simrs-vx/pkg/use-case-helper"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
e "simrs-vx/internal/domain/main-entities/installation"
|
|
egos "simrs-vx/internal/domain/simgos-entities/installation"
|
|
esync "simrs-vx/internal/domain/sync-entities/installation"
|
|
)
|
|
|
|
const source = "installation"
|
|
|
|
var now = time.Now()
|
|
|
|
func Create(input e.CreateDto) (*d.Data, error) {
|
|
sgData := egos.MInstalasi{}
|
|
event := pl.Event{
|
|
Feature: "Create",
|
|
Source: source,
|
|
}
|
|
|
|
// Start log
|
|
pl.SetLogInfo(&event, input, "started", "create")
|
|
|
|
err := dg.I.Transaction(func(tx *gorm.DB) error {
|
|
// Insert Simgos
|
|
sgData, err := CreateSimgosData(input, &event, tx)
|
|
if err != nil {
|
|
errMsg := err.Error()
|
|
inputLog := esync.InstallationSimxLog{
|
|
Date: &now,
|
|
Status: erc.PSCFailed,
|
|
ErrMessage: &errMsg,
|
|
}
|
|
|
|
// InsertSimxLog
|
|
if err = CreateSimxLogData(input, inputLog, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
inputLog := esync.InstallationSimxLog{
|
|
Date: &now,
|
|
Status: erc.PSCSuccess,
|
|
}
|
|
|
|
// InsertSimxLog
|
|
if err = CreateSimxLogData(input, inputLog, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// InsertSimxLink
|
|
if err = CreateInstallationLinkData(*input.Id, sgData.NoInstalasi, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
|
|
pl.SetLogInfo(&event, nil, "complete")
|
|
|
|
return nil
|
|
})
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &d.Data{
|
|
Meta: d.II{
|
|
"source": source,
|
|
"structure": "single-data",
|
|
"status": "created",
|
|
},
|
|
Data: sgData,
|
|
}, nil
|
|
}
|
|
|
|
func ReadList(input e.ReadListDto) (*d.Data, error) {
|
|
var data *e.Installation
|
|
var dataList []e.Installation
|
|
var metaList *e.MetaDto
|
|
var err error
|
|
|
|
event := pl.Event{
|
|
Feature: "ReadList",
|
|
Source: source,
|
|
}
|
|
|
|
// Start log
|
|
pl.SetLogInfo(&event, input, "started", "readList")
|
|
|
|
err = dg.I.Transaction(func(tx *gorm.DB) error {
|
|
mwRunner := newMiddlewareRunner(&event, tx)
|
|
mwRunner.setMwType(pu.MWTPre)
|
|
// Run pre-middleware
|
|
if err := mwRunner.RunReadListMiddleware(readListPreMw, &input, data); err != nil {
|
|
return err
|
|
}
|
|
|
|
if dataList, metaList, err = ReadListData(input, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
|
|
mwRunner.setMwType(pu.MWTPost)
|
|
// Run post-middleware
|
|
if err := mwRunner.RunReadListMiddleware(readListPostMw, &input, data); err != nil {
|
|
return err
|
|
}
|
|
|
|
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),
|
|
"record_currentCount": strconv.Itoa(len(dataList)),
|
|
},
|
|
Data: e.ToResponseList(dataList),
|
|
}, nil
|
|
}
|
|
|
|
func ReadDetail(input e.ReadDetailDto) (*d.Data, error) {
|
|
var data *e.Installation
|
|
var err error
|
|
|
|
event := pl.Event{
|
|
Feature: "ReadDetail",
|
|
Source: source,
|
|
}
|
|
|
|
// Start log
|
|
pl.SetLogInfo(&event, input, "started", "readDetail")
|
|
|
|
err = dg.I.Transaction(func(tx *gorm.DB) error {
|
|
mwRunner := newMiddlewareRunner(&event, tx)
|
|
mwRunner.setMwType(pu.MWTPre)
|
|
// Run pre-middleware
|
|
if err := mwRunner.RunReadDetailMiddleware(readDetailPreMw, &input, data); err != nil {
|
|
return err
|
|
}
|
|
|
|
if data, err = ReadDetailData(input, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
|
|
mwRunner.setMwType(pu.MWTPost)
|
|
// Run post-middleware
|
|
if err := mwRunner.RunReadDetailMiddleware(readDetailPostMw, &input, data); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
})
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &d.Data{
|
|
Meta: d.IS{
|
|
"source": source,
|
|
"structure": "single-data",
|
|
"status": "fetched",
|
|
},
|
|
Data: data.ToResponse(),
|
|
}, nil
|
|
}
|
|
|
|
//func Update(input e.UpdateDto) (*d.Data, error) {
|
|
// rdDto := e.ReadDetailDto{Code: input.Code}
|
|
// var data *e.Installation
|
|
// var err error
|
|
//
|
|
// event := pl.Event{
|
|
// Feature: "Update",
|
|
// Source: source,
|
|
// }
|
|
//
|
|
// // Start log
|
|
// pl.SetLogInfo(&event, input, "started", "update")
|
|
//
|
|
// err = dg.I.Transaction(func(tx *gorm.DB) error {
|
|
// pl.SetLogInfo(&event, rdDto, "started", "DBReadDetail")
|
|
// if data, err = ReadDetailData(rdDto, &event, tx); err != nil {
|
|
// return err
|
|
// }
|
|
//
|
|
// mwRunner := newMiddlewareRunner(&event, tx)
|
|
// mwRunner.setMwType(pu.MWTPre)
|
|
// // Run pre-middleware
|
|
// if err := mwRunner.RunUpdateMiddleware(readDetailPreMw, &rdDto, data); err != nil {
|
|
// return err
|
|
// }
|
|
//
|
|
// if err := UpdateData(input, data, &event, tx); err != nil {
|
|
// return err
|
|
// }
|
|
//
|
|
// pl.SetLogInfo(&event, nil, "complete")
|
|
//
|
|
// mwRunner.setMwType(pu.MWTPost)
|
|
// // Run post-middleware
|
|
// if err := mwRunner.RunUpdateMiddleware(readDetailPostMw, &rdDto, data); err != nil {
|
|
// return err
|
|
// }
|
|
//
|
|
// return nil
|
|
// })
|
|
//
|
|
// if err != nil {
|
|
// return nil, err
|
|
// }
|
|
//
|
|
// return &d.Data{
|
|
// Meta: d.IS{
|
|
// "source": source,
|
|
// "structure": "single-data",
|
|
// "status": "updated",
|
|
// },
|
|
// Data: data.ToResponse(),
|
|
// }, nil
|
|
//
|
|
//}
|
|
|
|
func Delete(input e.DeleteDto) (*d.Data, error) {
|
|
rdDto := e.ReadDetailDto{Code: input.Code}
|
|
var data *e.Installation
|
|
var err error
|
|
|
|
event := pl.Event{
|
|
Feature: "Delete",
|
|
Source: source,
|
|
}
|
|
|
|
// Start log
|
|
pl.SetLogInfo(&event, input, "started", "delete")
|
|
|
|
err = dg.I.Transaction(func(tx *gorm.DB) error {
|
|
pl.SetLogInfo(&event, rdDto, "started", "DBReadDetail")
|
|
if data, err = ReadDetailData(rdDto, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
|
|
mwRunner := newMiddlewareRunner(&event, tx)
|
|
mwRunner.setMwType(pu.MWTPre)
|
|
// Run pre-middleware
|
|
if err := mwRunner.RunDeleteMiddleware(readDetailPreMw, &rdDto, data); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := DeleteData(data, &event, tx); err != nil {
|
|
return err
|
|
}
|
|
|
|
mwRunner.setMwType(pu.MWTPost)
|
|
// Run post-middleware
|
|
if err := mwRunner.RunDeleteMiddleware(readDetailPostMw, &rdDto, data); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
})
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &d.Data{
|
|
Meta: d.IS{
|
|
"source": source,
|
|
"structure": "single-data",
|
|
"status": "deleted",
|
|
},
|
|
Data: data.ToResponse(),
|
|
}, nil
|
|
|
|
}
|