feat (vclaim-sep): create, read, delete done
This commit is contained in:
@@ -57,9 +57,6 @@ corsCfg:
|
||||
satuSehatCfg:
|
||||
host: localhost:8200
|
||||
|
||||
bpjsCfg:
|
||||
host: localhost:8200
|
||||
|
||||
corsCfg:
|
||||
allowedOrigins:
|
||||
- http://example.com
|
||||
|
||||
@@ -57,9 +57,6 @@ corsCfg:
|
||||
satuSehatCfg:
|
||||
host: localhost:8200
|
||||
|
||||
bpjsCfg:
|
||||
host: localhost:8200
|
||||
|
||||
corsCfg:
|
||||
allowedOrigins:
|
||||
- http://example.com
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package vclaimsep
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
ecore "simrs-vx/internal/domain/base-entities/core"
|
||||
evsh "simrs-vx/internal/domain/bpjs-entities/vclaim-sep-hist"
|
||||
)
|
||||
@@ -8,7 +9,7 @@ import (
|
||||
type CreateDto struct {
|
||||
Encounter_Id *uint `json:"encounter_id"`
|
||||
Number *string `json:"number" validate:"maxLength=19"`
|
||||
RequestPayload []byte `json:"requestPayload" validate:"maxLength=1024"`
|
||||
RequestPayload string `json:"requestPayload" validate:"maxLength=1024"`
|
||||
|
||||
VclaimSepHist evsh.CreateDto
|
||||
}
|
||||
@@ -25,8 +26,9 @@ type FilterDto struct {
|
||||
}
|
||||
|
||||
type ReadDetailDto struct {
|
||||
Id uint `json:"id"`
|
||||
Number *string `json:"number"`
|
||||
Id uint `json:"id"`
|
||||
Number *string `json:"number"`
|
||||
Encounter_Id *uint `json:"encounter_id"`
|
||||
}
|
||||
|
||||
type UpdateDto struct {
|
||||
@@ -47,14 +49,16 @@ type MetaDto struct {
|
||||
|
||||
type ResponseDto struct {
|
||||
ecore.Main
|
||||
Encounter_Id *uint `json:"encounter_id"`
|
||||
Number *string `json:"number"`
|
||||
Encounter_Id *uint `json:"encounter_id"`
|
||||
Number *string `json:"number"`
|
||||
Detail *SepDetail `json:"detail,omitempty"`
|
||||
}
|
||||
|
||||
func (d VclaimSep) ToResponse() ResponseDto {
|
||||
resp := ResponseDto{
|
||||
Encounter_Id: d.Encounter_Id,
|
||||
Number: d.Number,
|
||||
Detail: d.Detail,
|
||||
}
|
||||
resp.Main = d.Main
|
||||
return resp
|
||||
@@ -71,3 +75,130 @@ func ToResponseList(data []VclaimSep) []ResponseDto {
|
||||
func (c CreateDto) IsMessageSuccess() bool {
|
||||
return c.VclaimSepHist.Message == "Sukses"
|
||||
}
|
||||
|
||||
func (c CreateDto) RequestPayloadIntoJson() ([]byte, error) {
|
||||
payload := map[string]interface{}{}
|
||||
err := json.Unmarshal([]byte(c.RequestPayload), &payload)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return json.Marshal(payload)
|
||||
}
|
||||
|
||||
func (c CreateDto) RequestPayloadWithEncounterId() ([]byte, error) {
|
||||
payload := map[string]interface{}{}
|
||||
|
||||
err := json.Unmarshal([]byte(c.RequestPayload), &payload)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
payload["encounter_id"] = c.Encounter_Id
|
||||
|
||||
return json.Marshal(payload)
|
||||
}
|
||||
|
||||
type SepResponse struct {
|
||||
MetaData MetaData `json:"metaData"`
|
||||
Response *SepDetail `json:"response"`
|
||||
}
|
||||
|
||||
type MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
}
|
||||
|
||||
type SepDetail struct {
|
||||
AssestmenPel AssestmenPel `json:"assestmenPel"`
|
||||
Catatan string `json:"catatan"`
|
||||
Cob string `json:"cob"`
|
||||
Diagnosa string `json:"diagnosa"`
|
||||
Dpjp Dpjp `json:"dpjp"`
|
||||
ESep string `json:"eSEP"`
|
||||
FlagProcedure FlagProcedure `json:"flagProcedure"`
|
||||
Informasi any `json:"informasi"` // null = interface{}
|
||||
JnsPelayanan string `json:"jnsPelayanan"`
|
||||
Katarak string `json:"katarak"`
|
||||
KdPenunjang KdPenunjang `json:"kdPenunjang"`
|
||||
KdStatusKecelakaan string `json:"kdStatusKecelakaan"`
|
||||
KelasRawat string `json:"kelasRawat"`
|
||||
KlsRawat KlsRawat `json:"klsRawat"`
|
||||
Kontrol Kontrol `json:"kontrol"`
|
||||
LokasiKejadian LokasiKejadian `json:"lokasiKejadian"`
|
||||
NmStatusKecelakaan string `json:"nmstatusKecelakaan"`
|
||||
NoRujukan string `json:"noRujukan"`
|
||||
NoSep string `json:"noSep"`
|
||||
Penjamin any `json:"penjamin"` // null
|
||||
Peserta Peserta `json:"peserta"`
|
||||
Poli string `json:"poli"`
|
||||
PoliEksekutif string `json:"poliEksekutif"`
|
||||
TglSep string `json:"tglSep"`
|
||||
TujuanKunj TujuanKunj `json:"tujuanKunj"`
|
||||
}
|
||||
|
||||
type AssestmenPel struct {
|
||||
Kode string `json:"kode"`
|
||||
Nama string `json:"nama"`
|
||||
}
|
||||
|
||||
type Dpjp struct {
|
||||
KdDPJP string `json:"kdDPJP"`
|
||||
NmDPJP string `json:"nmDPJP"`
|
||||
}
|
||||
|
||||
type FlagProcedure struct {
|
||||
Kode string `json:"kode"`
|
||||
Nama string `json:"nama"`
|
||||
}
|
||||
|
||||
type KdPenunjang struct {
|
||||
Kode string `json:"kode"`
|
||||
Nama string `json:"nama"`
|
||||
}
|
||||
|
||||
type KlsRawat struct {
|
||||
KlsRawatHak string `json:"klsRawatHak"`
|
||||
KlsRawatNaik *string `json:"klsRawatNaik"` // nullable
|
||||
Pembiayaan *string `json:"pembiayaan"` // nullable
|
||||
PenanggungJawab *string `json:"penanggungJawab"` // nullable
|
||||
}
|
||||
|
||||
type Kontrol struct {
|
||||
KdDokter *string `json:"kdDokter"` // null
|
||||
NmDokter *string `json:"nmDokter"` // null
|
||||
NoSurat *string `json:"noSurat"` // null
|
||||
}
|
||||
|
||||
type LokasiKejadian struct {
|
||||
KdKab *string `json:"kdKab"`
|
||||
KdKec *string `json:"kdKec"`
|
||||
KdProp *string `json:"kdProp"`
|
||||
KetKejadian *string `json:"ketKejadian"`
|
||||
Lokasi *string `json:"lokasi"`
|
||||
TglKejadian *string `json:"tglKejadian"`
|
||||
}
|
||||
|
||||
type Peserta struct {
|
||||
Asuransi any `json:"asuransi"`
|
||||
HakKelas string `json:"hakKelas"`
|
||||
JnsPeserta string `json:"jnsPeserta"`
|
||||
Kelamin string `json:"kelamin"`
|
||||
Nama string `json:"nama"`
|
||||
NoKartu string `json:"noKartu"`
|
||||
NoMR string `json:"noMr"`
|
||||
TglLahir string `json:"tglLahir"`
|
||||
}
|
||||
|
||||
type TujuanKunj struct {
|
||||
Kode string `json:"kode"`
|
||||
Nama string `json:"nama"`
|
||||
}
|
||||
|
||||
type SepDeleteRequest struct {
|
||||
Request struct {
|
||||
TSep struct {
|
||||
NoSep string `json:"noSep"`
|
||||
User string `json:"user"`
|
||||
} `json:"t_sep"`
|
||||
} `json:"request"`
|
||||
}
|
||||
|
||||
@@ -12,4 +12,5 @@ type VclaimSep struct {
|
||||
Number *string `json:"number" gorm:"unique;size:19"`
|
||||
Prints []*evsp.VclaimSepPrint `json:"prints,omitempty" gorm:"foreignKey:VclaimSep_Number;references:Number"`
|
||||
ControlLetters []*evscl.VclaimSepControlLetter `json:"controlLetters,omitempty" gorm:"foreignKey:VclaimSep_Number;references:Number"`
|
||||
Detail *SepDetail `json:"detail,omitempty" gorm:"-"`
|
||||
}
|
||||
|
||||
@@ -87,5 +87,5 @@ func (d Encounter) IsSameResponsibleDoctor(input *string) bool {
|
||||
if input == nil {
|
||||
return false
|
||||
}
|
||||
return d.Responsible_Doctor_Code == input
|
||||
return *d.Responsible_Doctor_Code == *input
|
||||
}
|
||||
|
||||
@@ -4,12 +4,12 @@ import (
|
||||
"net/http"
|
||||
|
||||
/******************** main / transaction ********************/
|
||||
member "simrs-vx/internal/interface/bpjs-handler/member"
|
||||
monitoring "simrs-vx/internal/interface/bpjs-handler/monitoring"
|
||||
reference "simrs-vx/internal/interface/bpjs-handler/reference"
|
||||
vclaimsep "simrs-vx/internal/interface/bpjs-handler/vclaim-sep"
|
||||
vclaimsephist "simrs-vx/internal/interface/bpjs-handler/vclaim-sep-hist"
|
||||
vclaimsepprint "simrs-vx/internal/interface/bpjs-handler/vclaim-sep-print"
|
||||
member "simrs-vx/internal/interface/main-handler/member"
|
||||
monitoring "simrs-vx/internal/interface/main-handler/monitoring"
|
||||
reference "simrs-vx/internal/interface/main-handler/reference"
|
||||
vclaimsep "simrs-vx/internal/interface/main-handler/vclaim-sep"
|
||||
vclaimsephist "simrs-vx/internal/interface/main-handler/vclaim-sep-hist"
|
||||
vclaimsepprint "simrs-vx/internal/interface/main-handler/vclaim-sep-print"
|
||||
|
||||
/******************** actor ********************/
|
||||
|
||||
@@ -49,7 +49,7 @@ func SetRoutes() http.Handler {
|
||||
|
||||
hk.GroupRoutes("/v1/vclaim-sep", r, hk.MapHandlerFunc{
|
||||
"POST /": vclaimsep.O.Create,
|
||||
"PATCH /{id}": vclaimsep.O.Update,
|
||||
"PATCH /{id}": vclaimsep.O.GetDetail,
|
||||
"DELETE /{id}": vclaimsep.O.Delete,
|
||||
})
|
||||
|
||||
|
||||
@@ -120,9 +120,17 @@ import (
|
||||
regency "simrs-vx/internal/interface/main-handler/regency"
|
||||
village "simrs-vx/internal/interface/main-handler/village"
|
||||
|
||||
///// Internal
|
||||
/******************** Internal ********************/
|
||||
validation "simrs-vx/internal/interface/main-handler/helper/validation"
|
||||
"simrs-vx/internal/interface/main-handler/home"
|
||||
|
||||
/******************** BPJS ********************/
|
||||
member "simrs-vx/internal/interface/main-handler/member"
|
||||
monitoring "simrs-vx/internal/interface/main-handler/monitoring"
|
||||
reference "simrs-vx/internal/interface/main-handler/reference"
|
||||
vclaimsep "simrs-vx/internal/interface/main-handler/vclaim-sep"
|
||||
vclaimsephist "simrs-vx/internal/interface/main-handler/vclaim-sep-hist"
|
||||
vclaimsepprint "simrs-vx/internal/interface/main-handler/vclaim-sep-print"
|
||||
)
|
||||
|
||||
// One place route to relatively easier to manage, ESPECIALLY in tracking
|
||||
@@ -138,6 +146,7 @@ func SetRoutes() http.Handler {
|
||||
a.RegisterExtCall(validation.RegisterValidation)
|
||||
a.RegisterExtCall(simgossync.SetConfig)
|
||||
a.RegisterExtCall(docscfg.ParseCfg)
|
||||
a.RegisterExtCall(ibpjs.SetConfig)
|
||||
|
||||
r := http.NewServeMux()
|
||||
|
||||
@@ -371,6 +380,43 @@ func SetRoutes() http.Handler {
|
||||
hc.RegCrudByCode(r, "/v1/province", province.O)
|
||||
hc.RegCrudByCode(r, "/v1/postal-region", postalregion.O)
|
||||
|
||||
/******************** BPJS ********************/
|
||||
hk.GroupRoutes("/v1/vclaim-sep", r, hk.MapHandlerFunc{
|
||||
"POST /": vclaimsep.O.Create,
|
||||
"GET /{id}": vclaimsep.O.GetDetail,
|
||||
"DELETE /{id}": vclaimsep.O.Delete,
|
||||
})
|
||||
|
||||
hk.GroupRoutes("/v1/vclaim-sep-hist", r, hk.MapHandlerFunc{
|
||||
"GET /": vclaimsephist.O.GetList,
|
||||
})
|
||||
|
||||
hk.GroupRoutes("/v1/vclaim-sep-print", r, hk.MapHandlerFunc{
|
||||
"POST /": vclaimsepprint.O.Create,
|
||||
})
|
||||
|
||||
hk.GroupRoutes("/v1/reference", r, hk.MapHandlerFunc{
|
||||
"GET /province": reference.GetListProvince,
|
||||
"GET /regency/{provinceCode}": reference.GetListCities,
|
||||
"GET /district/{regencyCode}": reference.GetListDistrict,
|
||||
"GET /diagnose/{keyword}": reference.GetListDiagnose,
|
||||
"GET /diagnose-prb": reference.GetListDiagnosePrb,
|
||||
"GET /medicine-prb/{keyword}": reference.GetListMedicinePrb,
|
||||
"GET /unit/{unitCode}": reference.GetListUnit,
|
||||
"GET /healthcare/{healthcare}/{healthcareType}": reference.GetListHealthcare,
|
||||
"GET /responsible-doctor/{serviceType}/{serviceDate}/{specialistCode}": reference.GetListDoctor,
|
||||
})
|
||||
|
||||
hk.GroupRoutes("/v1/member", r, hk.MapHandlerFunc{
|
||||
"GET /bpjs/{cardNumber}/{sepDate}": member.GetListByBpjsNumber,
|
||||
"GET /nik/{nik}/{sepDate}": member.GetListByNik,
|
||||
})
|
||||
|
||||
hk.GroupRoutes("/v1/monitoring", r, hk.MapHandlerFunc{
|
||||
"GET /visit/{date}/{serviceType}": monitoring.GetListVisit,
|
||||
"GET /hist/{cardNumber}/{startDate}/{endDate}": monitoring.GetListHist,
|
||||
})
|
||||
|
||||
/////
|
||||
return cmw.SetCors(handlerlogger.SetLog(r))
|
||||
}
|
||||
|
||||
@@ -99,9 +99,6 @@ func Verify(w http.ResponseWriter, r *http.Request) {
|
||||
}
|
||||
|
||||
dto := e.UpdateDto{}
|
||||
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||
return
|
||||
}
|
||||
dto.Id = uint(id)
|
||||
dto.Status_Code = erc.DVCVerified
|
||||
dto.AuthInfo = *authInfo
|
||||
@@ -120,9 +117,6 @@ func Validate(w http.ResponseWriter, r *http.Request) {
|
||||
}
|
||||
|
||||
dto := e.UpdateDto{}
|
||||
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||
return
|
||||
}
|
||||
dto.Id = uint(id)
|
||||
dto.Status_Code = erc.DVCValidated
|
||||
dto.AuthInfo = *authInfo
|
||||
|
||||
+25
-31
@@ -1,7 +1,6 @@
|
||||
package vclaimsep
|
||||
|
||||
import (
|
||||
"io"
|
||||
"net/http"
|
||||
|
||||
rw "github.com/karincake/risoles"
|
||||
@@ -16,14 +15,9 @@ var O myBase
|
||||
|
||||
func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
|
||||
dto := e.CreateDto{}
|
||||
body, err := io.ReadAll(r.Body)
|
||||
if err != nil {
|
||||
http.Error(w, "failed to read body", http.StatusBadRequest)
|
||||
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||
return
|
||||
}
|
||||
defer r.Body.Close()
|
||||
|
||||
dto.RequestPayload = body
|
||||
res, err := u.Create(dto)
|
||||
rw.DataResponse(w, res, err)
|
||||
}
|
||||
@@ -35,39 +29,39 @@ func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
|
||||
// rw.DataResponse(w, res, err)
|
||||
// }
|
||||
|
||||
// func (obj myBase) GetDetail(w http.ResponseWriter, r *http.Request) {
|
||||
// id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||
// if id <= 0 {
|
||||
func (obj myBase) GetDetail(w http.ResponseWriter, r *http.Request) {
|
||||
id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||
if id <= 0 {
|
||||
return
|
||||
}
|
||||
dto := e.ReadDetailDto{}
|
||||
dto.Id = uint(id)
|
||||
res, err := u.ReadDetail(dto)
|
||||
rw.DataResponse(w, res, err)
|
||||
}
|
||||
|
||||
// func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
||||
// number := rw.ValidateString(w, "number", r.PathValue("number"))
|
||||
// if number != "" {
|
||||
// return
|
||||
// }
|
||||
// dto := e.ReadDetailDto{}
|
||||
// dto.Id = uint(id)
|
||||
// res, err := u.ReadDetail(dto)
|
||||
|
||||
// dto := e.UpdateDto{}
|
||||
// if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||
// return
|
||||
// }
|
||||
// dto.Number = &number
|
||||
// res, err := u.Update(dto)
|
||||
// rw.DataResponse(w, res, err)
|
||||
// }
|
||||
|
||||
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
||||
number := rw.ValidateString(w, "number", r.PathValue("number"))
|
||||
if number != "" {
|
||||
return
|
||||
}
|
||||
|
||||
dto := e.UpdateDto{}
|
||||
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||
return
|
||||
}
|
||||
dto.Number = &number
|
||||
res, err := u.Update(dto)
|
||||
rw.DataResponse(w, res, err)
|
||||
}
|
||||
|
||||
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
|
||||
number := rw.ValidateString(w, "number", r.PathValue("number"))
|
||||
if number != "" {
|
||||
id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||
if id <= 0 {
|
||||
return
|
||||
}
|
||||
dto := e.DeleteDto{}
|
||||
dto.Number = &number
|
||||
dto.Id = uint(id)
|
||||
res, err := u.Delete(dto)
|
||||
rw.DataResponse(w, res, err)
|
||||
}
|
||||
@@ -14,7 +14,11 @@ import (
|
||||
)
|
||||
|
||||
func CreateSep(input *e.CreateDto, data *e.VclaimSep, tx *gorm.DB) error {
|
||||
req, err := http.NewRequest("POST", ibpjs.O.BaseUrl+"/sep", bytes.NewReader(input.RequestPayload))
|
||||
payload, err := input.RequestPayloadIntoJson()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
req, err := http.NewRequest("POST", ibpjs.O.BaseUrl+"sep", bytes.NewBuffer(payload))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@@ -43,7 +47,11 @@ func CreateSep(input *e.CreateDto, data *e.VclaimSep, tx *gorm.DB) error {
|
||||
}
|
||||
|
||||
// Save request/response details in DTO for further use
|
||||
input.VclaimSepHist.RequestPayload = string(input.RequestPayload)
|
||||
reqPayload, err := input.RequestPayloadWithEncounterId()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
input.VclaimSepHist.RequestPayload = string(reqPayload)
|
||||
input.VclaimSepHist.ResponseBody = string(body)
|
||||
input.VclaimSepHist.Message = msg
|
||||
input.Number = func() *string {
|
||||
@@ -56,3 +64,72 @@ func CreateSep(input *e.CreateDto, data *e.VclaimSep, tx *gorm.DB) error {
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func ReadDetailSep(input *e.ReadDetailDto, data *e.VclaimSep, tx *gorm.DB) error {
|
||||
endpoint := fmt.Sprintf("sep/%s", *data.Number)
|
||||
req, err := http.NewRequest("GET", ibpjs.O.BaseUrl+endpoint, nil)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
req.Header.Set("Content-Type", "application/json")
|
||||
|
||||
resp, err := http.DefaultClient.Do(req)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
body, err := io.ReadAll(resp.Body)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
var detail e.SepResponse
|
||||
if err := json.Unmarshal(body, &detail); err != nil {
|
||||
return fmt.Errorf("failed to parse response JSON: %w", err)
|
||||
}
|
||||
|
||||
data.Detail = detail.Response
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func DeleteSep(input *e.DeleteDto, data *e.VclaimSep, tx *gorm.DB) error {
|
||||
payload := e.SepDeleteRequest{}
|
||||
payload.Request.TSep.NoSep = *data.Number
|
||||
payload.Request.TSep.User = "Coba Ws"
|
||||
|
||||
jsonPayload, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
req, err := http.NewRequest("DELETE", ibpjs.O.BaseUrl+"sep", bytes.NewBuffer(jsonPayload))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
req.Header.Set("Content-Type", "application/json")
|
||||
|
||||
resp, err := http.DefaultClient.Do(req)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
body, err := io.ReadAll(resp.Body)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
var detail e.SepResponse
|
||||
if err := json.Unmarshal(body, &detail); err != nil {
|
||||
return fmt.Errorf("failed to parse response JSON: %w", err)
|
||||
}
|
||||
|
||||
if detail.MetaData.Message == SepNotFound {
|
||||
return fmt.Errorf("sep with number %s not found", *data.Number)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
@@ -10,3 +10,5 @@ type vclaimResponse struct {
|
||||
} `json:"sep"`
|
||||
} `json:"response"`
|
||||
}
|
||||
|
||||
const SepNotFound = "Data Tidak Ditemukan"
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package vclaimsep
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"strconv"
|
||||
|
||||
e "simrs-vx/internal/domain/bpjs-entities/vclaim-sep"
|
||||
@@ -31,6 +32,17 @@ func Create(input e.CreateDto) (*d.Data, error) {
|
||||
pl.SetLogInfo(&event, input, "started", "create")
|
||||
|
||||
err := dg.I.Transaction(func(tx *gorm.DB) error {
|
||||
rDto := e.ReadDetailDto{Encounter_Id: input.Encounter_Id}
|
||||
if vSep, err := ReadDetailData(rDto, &event, tx); err != nil {
|
||||
if !pu.IsDataNotFoundError(err) {
|
||||
return err
|
||||
}
|
||||
|
||||
if vSep != nil {
|
||||
return fmt.Errorf("sep with encounter id %d already exist with number %s", input.Encounter_Id, *vSep.Number)
|
||||
}
|
||||
}
|
||||
|
||||
mwRunner := newMiddlewareRunner(&event, tx)
|
||||
mwRunner.setMwType(pu.MWTPre)
|
||||
// Run pre-middleware
|
||||
@@ -38,12 +50,12 @@ func Create(input e.CreateDto) (*d.Data, error) {
|
||||
return err
|
||||
}
|
||||
|
||||
if _, err := uvsh.CreateData(input.VclaimSepHist, &event, tx); err != nil {
|
||||
if _, err := uvsh.CreateData(input.VclaimSepHist, &event); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if !input.IsMessageSuccess() {
|
||||
return nil
|
||||
return fmt.Errorf("%s", input.VclaimSepHist.Message)
|
||||
}
|
||||
|
||||
if resData, err := CreateData(input, &event, tx); err != nil {
|
||||
@@ -234,7 +246,7 @@ func Update(input e.UpdateDto) (*d.Data, error) {
|
||||
}
|
||||
|
||||
func Delete(input e.DeleteDto) (*d.Data, error) {
|
||||
rdDto := e.ReadDetailDto{Number: input.Number}
|
||||
rdDto := e.ReadDetailDto{Id: input.Id}
|
||||
var data *e.VclaimSep
|
||||
var err error
|
||||
|
||||
@@ -255,7 +267,7 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
||||
mwRunner := newMiddlewareRunner(&event, tx)
|
||||
mwRunner.setMwType(pu.MWTPre)
|
||||
// Run pre-middleware
|
||||
if err := mwRunner.RunDeleteMiddleware(readDetailPreMw, &rdDto, data); err != nil {
|
||||
if err := mwRunner.RunDeleteMiddleware(deletePreMw, &e.DeleteDto{}, data); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
@@ -265,7 +277,7 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
||||
|
||||
mwRunner.setMwType(pu.MWTPost)
|
||||
// Run post-middleware
|
||||
if err := mwRunner.RunDeleteMiddleware(readDetailPostMw, &rdDto, data); err != nil {
|
||||
if err := mwRunner.RunDeleteMiddleware(deletePostMw, &e.DeleteDto{}, data); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
|
||||
@@ -87,6 +87,9 @@ func ReadDetailData(input e.ReadDetailDto, event *pl.Event, dbx ...*gorm.DB) (*e
|
||||
if input.Id != 0 {
|
||||
tx = tx.Where("\"Id\" = ?", input.Id)
|
||||
}
|
||||
if input.Encounter_Id != nil {
|
||||
tx = tx.Where("\"Encounter_Id\" = ?", *input.Encounter_Id)
|
||||
}
|
||||
|
||||
if err := tx.First(&data).Error; err != nil {
|
||||
if processedErr := pu.HandleReadError(err, event, source, input.Id, data); processedErr != nil {
|
||||
|
||||
@@ -83,7 +83,7 @@ func (me *middlewareRunner) RunUpdateMiddleware(middlewares []readDetailMw, inpu
|
||||
return nil
|
||||
}
|
||||
|
||||
func (me *middlewareRunner) RunDeleteMiddleware(middlewares []readDetailMw, input *e.ReadDetailDto, data *e.VclaimSep) error {
|
||||
func (me *middlewareRunner) RunDeleteMiddleware(middlewares []deleteMw, input *e.DeleteDto, data *e.VclaimSep) error {
|
||||
for _, middleware := range middlewares {
|
||||
logData := pu.GetLogData(input, data)
|
||||
|
||||
|
||||
@@ -9,5 +9,10 @@ func init() {
|
||||
createPreMw = append(createPreMw,
|
||||
createMw{Name: "create-sep", Func: pvs.CreateSep},
|
||||
)
|
||||
|
||||
readDetailPostMw = append(readDetailPostMw,
|
||||
readDetailMw{Name: "read-detail-sep", Func: pvs.ReadDetailSep},
|
||||
)
|
||||
deletePreMw = append(deletePreMw,
|
||||
deleteMw{Name: "delete-sep", Func: pvs.DeleteSep},
|
||||
)
|
||||
}
|
||||
|
||||
@@ -29,8 +29,12 @@ type readDetailMw struct {
|
||||
Func func(input *e.ReadDetailDto, data *e.VclaimSep, tx *gorm.DB) error
|
||||
}
|
||||
|
||||
type deleteMw struct {
|
||||
Name string
|
||||
Func func(input *e.DeleteDto, data *e.VclaimSep, tx *gorm.DB) error
|
||||
}
|
||||
|
||||
type UpdateMw = readDetailMw
|
||||
type DeleteMw = readDetailMw
|
||||
|
||||
var createPreMw []createMw // preprocess middleware
|
||||
var createPostMw []createMw // postprocess middleware
|
||||
@@ -40,5 +44,5 @@ var readDetailPreMw []readDetailMw
|
||||
var readDetailPostMw []readDetailMw
|
||||
var updatePreMw []readDetailMw
|
||||
var updatePostMw []readDetailMw
|
||||
var deletePreMw []readDetailMw
|
||||
var deletePostMw []readDetailMw
|
||||
var deletePreMw []deleteMw
|
||||
var deletePostMw []deleteMw
|
||||
|
||||
@@ -244,6 +244,10 @@ func generateResume(input GenerateDto, event pl.Event, tx *gorm.DB) (*ResponseDt
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if !r.IsValidated() {
|
||||
return nil, errors.New("resume is not validated")
|
||||
}
|
||||
|
||||
if r.FileUrl != nil {
|
||||
if err := removeFile(string(input.EntityType_Code), *r.FileUrl); err != nil {
|
||||
return nil, err
|
||||
|
||||
@@ -50,7 +50,6 @@ func Create(input e.CreateDto) (*d.Data, error) {
|
||||
return errors.New("encounter is already done")
|
||||
}
|
||||
|
||||
input.Status_Code = erc.DVCNew
|
||||
if resData, err := CreateData(input, &event, tx); err != nil {
|
||||
return err
|
||||
} else {
|
||||
@@ -345,16 +344,16 @@ func UpdateStatusCode(input e.UpdateDto) (*d.Data, error) {
|
||||
|
||||
switch input.Status_Code {
|
||||
case erc.DVCValidated:
|
||||
if !enc.IsSameResponsibleDoctor(input.AuthInfo.Doctor_Code) {
|
||||
return errors.New("validation doctor is not the same as encounter responsible doctor")
|
||||
}
|
||||
|
||||
if data.IsNew() {
|
||||
return errors.New("resume need to be verified first")
|
||||
}
|
||||
if data.IsValidated() {
|
||||
return errors.New("resume already validated")
|
||||
}
|
||||
if !enc.IsSameResponsibleDoctor(input.AuthInfo.Doctor_Code) {
|
||||
return errors.New("validation doctor is not the same as encounter responsible doctor")
|
||||
}
|
||||
|
||||
data.Status_Code = erc.DVCValidated
|
||||
err = tx.Save(&data).Error
|
||||
if err != nil {
|
||||
|
||||
@@ -6,12 +6,15 @@ package resume
|
||||
|
||||
import (
|
||||
e "simrs-vx/internal/domain/main-entities/resume"
|
||||
|
||||
erc "simrs-vx/internal/domain/references/common"
|
||||
)
|
||||
|
||||
func setData[T *e.CreateDto | *e.UpdateDto](input T, data *e.Resume) {
|
||||
var inputSrc *e.CreateDto
|
||||
if inputT, ok := any(input).(*e.CreateDto); ok {
|
||||
inputSrc = inputT
|
||||
data.Status_Code = erc.DVCNew
|
||||
} else {
|
||||
inputTemp := any(input).(*e.UpdateDto)
|
||||
inputSrc = &inputTemp.CreateDto
|
||||
@@ -20,5 +23,4 @@ func setData[T *e.CreateDto | *e.UpdateDto](input T, data *e.Resume) {
|
||||
data.Encounter_Id = inputSrc.Encounter_Id
|
||||
data.Doctor_Code = inputSrc.AuthInfo.Doctor_Code
|
||||
data.Value = inputSrc.Value
|
||||
data.Status_Code = inputSrc.Status_Code
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user