unit finish
This commit is contained in:
@@ -1,7 +1,6 @@
|
||||
package installation
|
||||
|
||||
import (
|
||||
"errors"
|
||||
esimgos "simrs-vx/internal/domain/simgos-entities/installation"
|
||||
esync "simrs-vx/internal/domain/sync-entities/log"
|
||||
|
||||
@@ -38,22 +37,23 @@ func Create(input e.CreateDto) (*d.Data, error) {
|
||||
}
|
||||
|
||||
// STEP 2: Insert to Link
|
||||
if err = CreateLinkData(*input.Id, sgData.No_Instalasi, &event, txSync); err != nil {
|
||||
syncLink, err := CreateLinkData(*input.Id, sgData.No_Instalasi, &event, txSync)
|
||||
if err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 3: Commit two trx
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
txSimgos.Rollback()
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
txSync.Rollback()
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
// STEP 4: Rollback Partial
|
||||
go func() {
|
||||
_ = DeleteSimgosData(sgData, &event)
|
||||
_ = DeleteLinkData(syncLink, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
@@ -106,9 +106,7 @@ func CreateSimxLog(input esync.SimxLogDto) (*d.Data, error) {
|
||||
|
||||
func Update(input e.UpdateDto) (*d.Data, error) {
|
||||
var (
|
||||
txSync = dg.I.Begin()
|
||||
txSimgos = dg.IS["simrs"].Begin()
|
||||
sgData *esimgos.MInstalasi
|
||||
err error
|
||||
)
|
||||
|
||||
@@ -121,51 +119,23 @@ func Update(input e.UpdateDto) (*d.Data, error) {
|
||||
pl.SetLogInfo(&event, input, "started", "update")
|
||||
|
||||
// STEP 1: Get Installation Link
|
||||
syncLink, errGetLink := ReadDetailLinkData(*input.Id, &event)
|
||||
if errGetLink != nil {
|
||||
if !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||
return nil, err
|
||||
}
|
||||
syncLink, err := ReadDetailLinkData(*input.Id, &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if errGetLink != nil && errors.Is(errGetLink, gorm.ErrRecordNotFound) {
|
||||
// STEP 2.1: Insert to simgos
|
||||
sgData, err = CreateSimgosData(input.CreateDto, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 2.2: Insert to Link
|
||||
simxId := uint(*input.Id)
|
||||
if err = CreateLinkData(simxId, sgData.No_Instalasi, &event, txSync); err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
} else {
|
||||
// Step 3.1: Update Simgos
|
||||
err = UpdateSimgosData(input, syncLink, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// Step 2: Update Simgos
|
||||
err = UpdateSimgosData(input, syncLink, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 4: Commit two trx
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
txSimgos.Rollback()
|
||||
txSync.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if errGetLink != nil {
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
// STEP 5.1: Rollback Partial
|
||||
go func() {
|
||||
_ = DeleteSimgosData(sgData, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
pl.SetLogInfo(&event, nil, "complete")
|
||||
|
||||
return &d.Data{
|
||||
@@ -194,52 +164,43 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
||||
pl.SetLogInfo(&event, input, "started", "delete")
|
||||
|
||||
// STEP 1: Get Installation Link
|
||||
syncLink, errGetLink := ReadDetailLinkData(*input.Id, &event)
|
||||
if errGetLink != nil {
|
||||
if !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||
return nil, err
|
||||
}
|
||||
syncLink, err := ReadDetailLinkData(*input.Id, &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if errGetLink == nil {
|
||||
// STEP 2: Get Simgos
|
||||
sgData, err = ReadDetailSimgosData(uint16(syncLink.Simgos_Id), &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// STEP 2: Get Simgos
|
||||
sgData, err = ReadDetailSimgosData(uint16(syncLink.Simgos_Id), &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 3: Delete M_Instalation Simgos
|
||||
err = DeleteSimgosData(sgData, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// STEP 3: Delete M_Instalation Simgos
|
||||
err = SoftDeleteSimgosData(sgData, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 4: Delete Installation Link
|
||||
err = DeleteLinkData(syncLink, &event, txSync)
|
||||
if err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
// STEP 4: Delete Installation Link
|
||||
err = DeleteLinkData(syncLink, &event, txSync)
|
||||
if err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 4: Commit two trx
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
txSimgos.Rollback()
|
||||
txSync.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
// STEP 4: Commit two trx
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
txSync.Rollback()
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
// STEP 5: Rollback Partial
|
||||
go func() {
|
||||
inputRollback := e.UpdateDto{
|
||||
CreateDto: e.CreateDto{
|
||||
Name: sgData.Nama_Instalasi,
|
||||
},
|
||||
}
|
||||
_ = UpdateSimgosData(inputRollback, syncLink, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
// STEP 5: Rollback Partial
|
||||
go func() {
|
||||
_, _ = CreateLinkData(uint(*input.Id), sgData.No_Instalasi, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
pl.SetLogInfo(&event, nil, "complete")
|
||||
|
||||
@@ -4,6 +4,7 @@ import (
|
||||
esynclog "simrs-vx/internal/domain/sync-entities/log"
|
||||
plh "simrs-vx/pkg/lib-helper"
|
||||
pl "simrs-vx/pkg/logger"
|
||||
pu "simrs-vx/pkg/use-case-helper"
|
||||
"time"
|
||||
|
||||
dg "github.com/karincake/apem/db-gorm-pg"
|
||||
@@ -45,7 +46,9 @@ func ReadDetailSimgosData(simgosId uint16, event *pl.Event) (*esimgos.MInstalasi
|
||||
if err := tx.
|
||||
Where("\"no_instalasi\" = ?", simgosId).
|
||||
First(&data).Error; err != nil {
|
||||
return nil, err
|
||||
if processedErr := pu.HandleReadError(err, event, source, simgosId, data); processedErr != nil {
|
||||
return nil, processedErr
|
||||
}
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
@@ -79,7 +82,32 @@ func UpdateSimgosData(input e.UpdateDto, dataSimgos *esync.InstallationLink, eve
|
||||
return nil
|
||||
}
|
||||
|
||||
func DeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
func HardDeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
pl.SetLogInfo(event, data, "started", "DBDelete")
|
||||
|
||||
var tx *gorm.DB
|
||||
if len(dbx) > 0 {
|
||||
tx = dbx[0]
|
||||
} else {
|
||||
tx = dg.IS["simrs"]
|
||||
}
|
||||
|
||||
if err := tx.
|
||||
Delete(&data).Error; err != nil {
|
||||
event.Status = "failed"
|
||||
event.ErrInfo = pl.ErrorInfo{
|
||||
Code: "data-delete-fail",
|
||||
Detail: "Database delete failed",
|
||||
Raw: err,
|
||||
}
|
||||
return pl.SetLogError(event, data)
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
return nil
|
||||
}
|
||||
|
||||
func SoftDeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
pl.SetLogInfo(event, data, "started", "DBDelete")
|
||||
|
||||
var tx *gorm.DB
|
||||
@@ -105,7 +133,7 @@ func DeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB
|
||||
return nil
|
||||
}
|
||||
|
||||
func CreateLinkData(simxId, simgosId uint, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
func CreateLinkData(simxId, simgosId uint, event *pl.Event, dbx ...*gorm.DB) (*esync.InstallationLink, error) {
|
||||
pl.SetLogInfo(event, nil, "started", "DBCreate")
|
||||
data := setDataSimxLink(simxId, simgosId)
|
||||
|
||||
@@ -117,11 +145,11 @@ func CreateLinkData(simxId, simgosId uint, event *pl.Event, dbx ...*gorm.DB) err
|
||||
}
|
||||
|
||||
if err := tx.Create(&data).Error; err != nil {
|
||||
return plh.HandleCreateError(data, event, err)
|
||||
return nil, plh.HandleCreateError(data, event, err)
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
return nil
|
||||
return &data, nil
|
||||
}
|
||||
|
||||
func ReadDetailLinkData(simxId uint16, event *pl.Event) (*esync.InstallationLink, error) {
|
||||
@@ -133,7 +161,9 @@ func ReadDetailLinkData(simxId uint16, event *pl.Event) (*esync.InstallationLink
|
||||
if err := tx.
|
||||
Where("\"Simx_Id\" = ?", simxId).
|
||||
First(&data).Error; err != nil {
|
||||
return nil, err
|
||||
if processedErr := pu.HandleReadError(err, event, source, simxId, data); processedErr != nil {
|
||||
return nil, processedErr
|
||||
}
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
|
||||
@@ -1,21 +1,18 @@
|
||||
package unit
|
||||
|
||||
import (
|
||||
"errors"
|
||||
esimgos "simrs-vx/internal/domain/simgos-entities/installation"
|
||||
esync "simrs-vx/internal/domain/sync-entities/log"
|
||||
pl "simrs-vx/pkg/logger"
|
||||
|
||||
dg "github.com/karincake/apem/db-gorm-pg"
|
||||
d "github.com/karincake/dodol"
|
||||
|
||||
pl "simrs-vx/pkg/logger"
|
||||
|
||||
"gorm.io/gorm"
|
||||
|
||||
e "simrs-vx/internal/domain/main-entities/installation"
|
||||
e "simrs-vx/internal/domain/main-entities/unit"
|
||||
esimgos "simrs-vx/internal/domain/simgos-entities/unit"
|
||||
esync "simrs-vx/internal/domain/sync-entities/log"
|
||||
)
|
||||
|
||||
const source = "installation"
|
||||
const source = "unit"
|
||||
|
||||
func Create(input e.CreateDto) (*d.Data, error) {
|
||||
var (
|
||||
@@ -38,22 +35,23 @@ func Create(input e.CreateDto) (*d.Data, error) {
|
||||
}
|
||||
|
||||
// STEP 2: Insert to Link
|
||||
if err = CreateLinkData(*input.Id, sgData.No_Instalasi, &event, txSync); err != nil {
|
||||
syncLink, err := CreateLinkData(*input.Id, sgData.Kode, &event, txSync)
|
||||
if err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 3: Commit two trx
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
txSimgos.Rollback()
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
txSync.Rollback()
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
// STEP 4: Rollback Partial
|
||||
go func() {
|
||||
_ = DeleteSimgosData(sgData, &event)
|
||||
_ = DeleteLinkData(syncLink, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
@@ -106,9 +104,7 @@ func CreateSimxLog(input esync.SimxLogDto) (*d.Data, error) {
|
||||
|
||||
func Update(input e.UpdateDto) (*d.Data, error) {
|
||||
var (
|
||||
txSync = dg.I.Begin()
|
||||
txSimgos = dg.IS["simrs"].Begin()
|
||||
sgData *esimgos.MInstalasi
|
||||
err error
|
||||
)
|
||||
|
||||
@@ -121,51 +117,23 @@ func Update(input e.UpdateDto) (*d.Data, error) {
|
||||
pl.SetLogInfo(&event, input, "started", "update")
|
||||
|
||||
// STEP 1: Get Installation Link
|
||||
syncLink, errGetLink := ReadDetailLinkData(*input.Id, &event)
|
||||
if errGetLink != nil {
|
||||
if !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||
return nil, err
|
||||
}
|
||||
syncLink, err := ReadDetailLinkData(*input.Id, &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if errGetLink != nil && errors.Is(errGetLink, gorm.ErrRecordNotFound) {
|
||||
// STEP 2.1: Insert to simgos
|
||||
sgData, err = CreateSimgosData(input.CreateDto, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 2.2: Insert to Link
|
||||
simxId := uint(*input.Id)
|
||||
if err = CreateLinkData(simxId, sgData.No_Instalasi, &event, txSync); err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
} else {
|
||||
// Step 3.1: Update Simgos
|
||||
err = UpdateSimgosData(input, syncLink, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// Step 2: Update Simgos
|
||||
err = UpdateSimgosData(input, syncLink, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 4: Commit two trx
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
txSimgos.Rollback()
|
||||
txSync.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if errGetLink != nil {
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
// STEP 5.1: Rollback Partial
|
||||
go func() {
|
||||
_ = DeleteSimgosData(sgData, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
pl.SetLogInfo(&event, nil, "complete")
|
||||
|
||||
return &d.Data{
|
||||
@@ -181,7 +149,7 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
||||
var (
|
||||
txSync = dg.I.Begin()
|
||||
txSimgos = dg.IS["simrs"].Begin()
|
||||
sgData *esimgos.MInstalasi
|
||||
sgData *esimgos.MPloy
|
||||
err error
|
||||
)
|
||||
|
||||
@@ -194,52 +162,43 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
||||
pl.SetLogInfo(&event, input, "started", "delete")
|
||||
|
||||
// STEP 1: Get Installation Link
|
||||
syncLink, errGetLink := ReadDetailLinkData(*input.Id, &event)
|
||||
if errGetLink != nil {
|
||||
if !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||
return nil, err
|
||||
}
|
||||
syncLink, err := ReadDetailLinkData(*input.Id, &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if errGetLink == nil {
|
||||
// STEP 2: Get Simgos
|
||||
sgData, err = ReadDetailSimgosData(uint16(syncLink.Simgos_Id), &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// STEP 2: Get Simgos
|
||||
sgData, err = ReadDetailSimgosData(uint16(syncLink.Simgos_Id), &event)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 3: Delete M_Instalation Simgos
|
||||
err = DeleteSimgosData(sgData, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// STEP 3: Delete M_Poly Simgos
|
||||
err = HardDeleteSimgosData(sgData, &event, txSimgos)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 4: Delete Installation Link
|
||||
err = DeleteLinkData(syncLink, &event, txSync)
|
||||
if err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
// STEP 4: Delete Installation Link
|
||||
err = DeleteLinkData(syncLink, &event, txSync)
|
||||
if err != nil {
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// STEP 4: Commit two trx
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
txSimgos.Rollback()
|
||||
txSync.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
// STEP 4: Commit two trx
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
txSync.Rollback()
|
||||
txSimgos.Rollback()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if err = txSync.Commit().Error; err != nil {
|
||||
// STEP 5: Rollback Partial
|
||||
go func() {
|
||||
inputRollback := e.UpdateDto{
|
||||
CreateDto: e.CreateDto{
|
||||
Name: sgData.Nama_Instalasi,
|
||||
},
|
||||
}
|
||||
_ = UpdateSimgosData(inputRollback, syncLink, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
if err = txSimgos.Commit().Error; err != nil {
|
||||
// STEP 5: Rollback Partial
|
||||
go func() {
|
||||
_, _ = CreateLinkData(uint(*input.Id), sgData.Kode, &event)
|
||||
}()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
pl.SetLogInfo(&event, nil, "complete")
|
||||
|
||||
@@ -8,14 +8,14 @@ import (
|
||||
"encoding/json"
|
||||
erc "simrs-vx/internal/domain/references/common"
|
||||
|
||||
e "simrs-vx/internal/domain/main-entities/installation"
|
||||
e "simrs-vx/internal/domain/main-entities/unit"
|
||||
|
||||
esimgos "simrs-vx/internal/domain/simgos-entities/unit"
|
||||
esync "simrs-vx/internal/domain/sync-entities/installation"
|
||||
esyncLog "simrs-vx/internal/domain/sync-entities/log"
|
||||
esync "simrs-vx/internal/domain/sync-entities/unit"
|
||||
)
|
||||
|
||||
func setDataSimgos[T *e.CreateDto | *e.UpdateDto](input T) (data esimgos.) {
|
||||
func setDataSimgos[T *e.CreateDto | *e.UpdateDto](input T) (data esimgos.MPloy) {
|
||||
var inputSrc *e.CreateDto
|
||||
if inputT, ok := any(input).(*e.CreateDto); ok {
|
||||
inputSrc = inputT
|
||||
@@ -24,14 +24,13 @@ func setDataSimgos[T *e.CreateDto | *e.UpdateDto](input T) (data esimgos.) {
|
||||
inputSrc = &inputTemp.CreateDto
|
||||
}
|
||||
|
||||
data.Nama_Instalasi = inputSrc.Name
|
||||
data.Status_Rawat_Inap = 0
|
||||
data.St_Aktif = 1
|
||||
data.Nama = inputSrc.Name
|
||||
data.Jenispoly = 0
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
func setDataSimxLog(input *esyncLog.SimxLogDto) (data esync.InstallationSimxLog) {
|
||||
func setDataSimxLog(input *esyncLog.SimxLogDto) (data esync.UnitSimxLog) {
|
||||
// encode to JSON
|
||||
jsonData, _ := json.MarshalIndent(input.Payload, "", " ")
|
||||
jsonString := string(jsonData)
|
||||
@@ -53,7 +52,7 @@ func setDataSimxLog(input *esyncLog.SimxLogDto) (data esync.InstallationSimxLog)
|
||||
return
|
||||
}
|
||||
|
||||
func setDataSimxLink(simxId, simgosId uint) (data esync.InstallationLink) {
|
||||
func setDataSimxLink(simxId, simgosId uint) (data esync.UnitLink) {
|
||||
data.Simx_Id = simxId
|
||||
data.Simgos_Id = simgosId
|
||||
return
|
||||
|
||||
@@ -1,22 +1,23 @@
|
||||
package unit
|
||||
|
||||
import (
|
||||
esynclog "simrs-vx/internal/domain/sync-entities/log"
|
||||
plh "simrs-vx/pkg/lib-helper"
|
||||
pl "simrs-vx/pkg/logger"
|
||||
pu "simrs-vx/pkg/use-case-helper"
|
||||
"time"
|
||||
|
||||
dg "github.com/karincake/apem/db-gorm-pg"
|
||||
"gorm.io/gorm"
|
||||
|
||||
e "simrs-vx/internal/domain/main-entities/installation"
|
||||
esimgos "simrs-vx/internal/domain/simgos-entities/installation"
|
||||
esync "simrs-vx/internal/domain/sync-entities/installation"
|
||||
e "simrs-vx/internal/domain/main-entities/unit"
|
||||
esimgos "simrs-vx/internal/domain/simgos-entities/unit"
|
||||
esynclog "simrs-vx/internal/domain/sync-entities/log"
|
||||
esync "simrs-vx/internal/domain/sync-entities/unit"
|
||||
)
|
||||
|
||||
var now = time.Now()
|
||||
|
||||
func CreateSimgosData(input e.CreateDto, event *pl.Event, dbx ...*gorm.DB) (*esimgos.MInstalasi, error) {
|
||||
func CreateSimgosData(input e.CreateDto, event *pl.Event, dbx ...*gorm.DB) (*esimgos.MPloy, error) {
|
||||
pl.SetLogInfo(event, nil, "started", "DBCreate")
|
||||
|
||||
data := setDataSimgos(&input)
|
||||
@@ -36,27 +37,29 @@ func CreateSimgosData(input e.CreateDto, event *pl.Event, dbx ...*gorm.DB) (*esi
|
||||
return &data, nil
|
||||
}
|
||||
|
||||
func ReadDetailSimgosData(simgosId uint16, event *pl.Event) (*esimgos.MInstalasi, error) {
|
||||
func ReadDetailSimgosData(simgosId uint16, event *pl.Event) (*esimgos.MPloy, error) {
|
||||
pl.SetLogInfo(event, simgosId, "started", "DBReadDetail")
|
||||
data := esimgos.MInstalasi{}
|
||||
data := esimgos.MPloy{}
|
||||
|
||||
var tx = dg.IS["simrs"]
|
||||
|
||||
if err := tx.
|
||||
Where("\"no_instalasi\" = ?", simgosId).
|
||||
Where("\"kode\" = ?", simgosId).
|
||||
First(&data).Error; err != nil {
|
||||
return nil, err
|
||||
if processedErr := pu.HandleReadError(err, event, source, simgosId, data); processedErr != nil {
|
||||
return nil, processedErr
|
||||
}
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
return &data, nil
|
||||
}
|
||||
|
||||
func UpdateSimgosData(input e.UpdateDto, dataSimgos *esync.InstallationLink, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
func UpdateSimgosData(input e.UpdateDto, dataSimgos *esync.UnitLink, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
pl.SetLogInfo(event, input, "started", "DBUpdate")
|
||||
|
||||
data := setDataSimgos(&input)
|
||||
data.No_Instalasi = dataSimgos.Simgos_Id
|
||||
data.Kode = dataSimgos.Simgos_Id
|
||||
|
||||
var tx *gorm.DB
|
||||
if len(dbx) > 0 {
|
||||
@@ -79,7 +82,7 @@ func UpdateSimgosData(input e.UpdateDto, dataSimgos *esync.InstallationLink, eve
|
||||
return nil
|
||||
}
|
||||
|
||||
func DeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
func HardDeleteSimgosData(data *esimgos.MPloy, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
pl.SetLogInfo(event, data, "started", "DBDelete")
|
||||
|
||||
var tx *gorm.DB
|
||||
@@ -89,9 +92,8 @@ func DeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB
|
||||
tx = dg.IS["simrs"]
|
||||
}
|
||||
|
||||
data.St_Aktif = 0
|
||||
|
||||
if err := tx.Save(&data).Error; err != nil {
|
||||
if err := tx.
|
||||
Delete(&data).Error; err != nil {
|
||||
event.Status = "failed"
|
||||
event.ErrInfo = pl.ErrorInfo{
|
||||
Code: "data-delete-fail",
|
||||
@@ -105,7 +107,7 @@ func DeleteSimgosData(data *esimgos.MInstalasi, event *pl.Event, dbx ...*gorm.DB
|
||||
return nil
|
||||
}
|
||||
|
||||
func CreateLinkData(simxId, simgosId uint, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
func CreateLinkData(simxId, simgosId uint, event *pl.Event, dbx ...*gorm.DB) (*esync.UnitLink, error) {
|
||||
pl.SetLogInfo(event, nil, "started", "DBCreate")
|
||||
data := setDataSimxLink(simxId, simgosId)
|
||||
|
||||
@@ -117,30 +119,32 @@ func CreateLinkData(simxId, simgosId uint, event *pl.Event, dbx ...*gorm.DB) err
|
||||
}
|
||||
|
||||
if err := tx.Create(&data).Error; err != nil {
|
||||
return plh.HandleCreateError(data, event, err)
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
return nil
|
||||
}
|
||||
|
||||
func ReadDetailLinkData(simxId uint16, event *pl.Event) (*esync.InstallationLink, error) {
|
||||
pl.SetLogInfo(event, simxId, "started", "DBReadDetail")
|
||||
data := esync.InstallationLink{}
|
||||
|
||||
var tx = dg.I
|
||||
|
||||
if err := tx.
|
||||
Where("\"Simx_Id\" = ?", simxId).
|
||||
First(&data).Error; err != nil {
|
||||
return nil, err
|
||||
return nil, plh.HandleCreateError(data, event, err)
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
return &data, nil
|
||||
}
|
||||
|
||||
func DeleteLinkData(data *esync.InstallationLink, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
func ReadDetailLinkData(simxId uint16, event *pl.Event) (*esync.UnitLink, error) {
|
||||
pl.SetLogInfo(event, simxId, "started", "DBReadDetail")
|
||||
data := esync.UnitLink{}
|
||||
|
||||
var tx = dg.I
|
||||
|
||||
if err := tx.
|
||||
Where("\"Simx_Id\" = ?", simxId).
|
||||
First(&data).Error; err != nil {
|
||||
if processedErr := pu.HandleReadError(err, event, source, simxId, data); processedErr != nil {
|
||||
return nil, processedErr
|
||||
}
|
||||
}
|
||||
|
||||
pl.SetLogInfo(event, nil, "complete")
|
||||
return &data, nil
|
||||
}
|
||||
|
||||
func DeleteLinkData(data *esync.UnitLink, event *pl.Event, dbx ...*gorm.DB) error {
|
||||
pl.SetLogInfo(event, data, "started", "DBDelete")
|
||||
|
||||
var tx *gorm.DB
|
||||
|
||||
Reference in New Issue
Block a user