move request validation to spesific folder

This commit is contained in:
vanilia
2025-10-22 15:28:26 +07:00
parent a2dd87a1b2
commit 73e4374366
4 changed files with 124 additions and 95 deletions
@@ -2,8 +2,6 @@ package encounter
import (
"errors"
"fmt"
uir "simrs-vx/internal/use-case/main-use-case/internal-reference"
"strconv"
ea "simrs-vx/internal/domain/main-entities/ambulatory"
@@ -419,59 +417,12 @@ func CheckOut(input e.DischargeDto) (*d.Data, error) {
switch *input.Discharge_Method_Code {
case ere.DMCDeath:
// insert data death-cause
if _, err := udc.CreateData(edc.CreateDto{
Encounter_Id: &input.Id,
Value: input.DeathCause,
}, &event, tx); err != nil {
if _, err = udc.CreateData(edc.CreateDto{Encounter_Id: &input.Id, Value: input.DeathCause}, &event, tx); err != nil {
return err
}
case ere.DMCConsulPoly, ere.DMCConsulExecutive:
unitIDs := make(map[uint16]struct{})
doctorIDs := make(map[uint]struct{})
for _, ref := range *input.InternalReferences {
if ref.Unit_Id != nil {
unitIDs[*ref.Unit_Id] = struct{}{}
}
if ref.Doctor_Id != nil {
doctorIDs[*ref.Doctor_Id] = struct{}{}
}
}
// validate unitIds
if len(unitIDs) > 0 {
var ids []uint16
for id := range unitIDs {
ids = append(ids, id)
}
units, err := getUnits(ids, &event, tx)
if err != nil {
return fmt.Errorf("failed to fetch units: %w", err)
}
if len(units) != len(ids) {
return fmt.Errorf("unit_id not found")
}
}
// validate doctorIds
if len(doctorIDs) > 0 {
var ids []uint
for id := range doctorIDs {
ids = append(ids, id)
}
doctors, err := getDoctors(ids, &event, tx)
if err != nil {
return fmt.Errorf("failed to fetch doctors: %w", err)
}
if len(doctors) != len(ids) {
return fmt.Errorf("doctor_id not found")
}
}
if err := uir.CreateBulkData(*input.InternalReferences, input.Id, &event, tx); err != nil {
// bulk insert internal-references
if err = createInternalReferences(input, &event, tx); err != nil {
return err
}
}
@@ -7,6 +7,7 @@ package encounter
import (
"errors"
"fmt"
uir "simrs-vx/internal/use-case/main-use-case/internal-reference"
"strings"
"time"
@@ -141,7 +142,9 @@ func createMedication(encounter_id uint, event *pl.Event, tx *gorm.DB) error {
return err
}
prescriptionItem, _, err := upi.ReadListData(epi.ReadListDto{FilterDto: epi.FilterDto{Prescription_Id: &prescription.Id}, Includes: "medicineMix"}, event, tx)
prescriptionItem, _, err := upi.ReadListData(epi.ReadListDto{
FilterDto: epi.FilterDto{Prescription_Id: &prescription.Id},
Includes: "medicineMix,medicineMix-MixItems"}, event, tx)
if err != nil {
return err
}
@@ -324,6 +327,68 @@ func setDataUpdateStatus(src e.UpdateStatusDto, dst *e.Encounter) {
dst.Status_Code = src.StatusCode
}
func createInternalReferences(input e.DischargeDto, event *pl.Event, tx *gorm.DB) error {
unitIDs := make(map[uint16]struct{})
doctorIDs := make(map[uint]struct{})
for _, ref := range *input.InternalReferences {
if ref.Unit_Id != nil {
unitIDs[*ref.Unit_Id] = struct{}{}
}
if ref.Doctor_Id != nil {
doctorIDs[*ref.Doctor_Id] = struct{}{}
}
}
// validate unitIds
if len(unitIDs) > 0 {
var ids []uint16
for id := range unitIDs {
ids = append(ids, id)
}
units, err := getUnits(ids, event, tx)
if err != nil {
return fmt.Errorf("failed to fetch units: %w", err)
}
if len(units) != len(ids) {
event.Status = "failed"
event.ErrInfo = pl.ErrorInfo{
Code: "data-validation-fail",
Detail: "unit_id not found",
}
return pl.SetLogError(event, nil)
}
}
// validate doctorIds
if len(doctorIDs) > 0 {
var ids []uint
for id := range doctorIDs {
ids = append(ids, id)
}
doctors, err := getDoctors(ids, event, tx)
if err != nil {
return fmt.Errorf("failed to fetch doctors: %w", err)
}
if len(doctors) != len(ids) {
event.Status = "failed"
event.ErrInfo = pl.ErrorInfo{
Code: "data-validation-fail",
Detail: "doctor_id not found",
}
return pl.SetLogError(event, nil)
}
}
if err := uir.CreateBulkData(*input.InternalReferences, input.Id, event, tx); err != nil {
return err
}
return nil
}
func getUnits(unitIds []uint16, event *pl.Event, tx *gorm.DB) ([]eu.Unit, error) {
pl.SetLogInfo(event, nil, "started", "getUnits")
var units []eu.Unit