Merge pull request #153 from dikstub-rssa/feat/improve-uploads-154
Feat/improve uploads 154
This commit is contained in:
@@ -8,13 +8,16 @@ type (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
UCPRN UploadCode = "person-resident-number" // Person Resident Number
|
UCPRN UploadCode = "person-resident-number" // Person Resident Number
|
||||||
UCPDL UploadCode = "person-driver-license" // Person Driver License
|
UCPDL UploadCode = "person-driver-license" // Person Driver License
|
||||||
UCPP UploadCode = "person-passport" // Person Passport
|
UCPP UploadCode = "person-passport" // Person Passport
|
||||||
UCPFC UploadCode = "person-family-card" // Person Family Card
|
UCPFC UploadCode = "person-family-card" // Person Family Card
|
||||||
UCMIR UploadCode = "mcu-item-result" // Mcu Item Result
|
UCMIR UploadCode = "mcu-item-result" // Mcu Item Result
|
||||||
UCSEP UploadCode = "vclaim-sep" // SEP
|
UCEnPatient UploadCode = "encounter-patient"
|
||||||
UCSIPP UploadCode = "vclaim-sipp" // SIPP
|
UCEnSupport UploadCode = "encounter-support"
|
||||||
|
UcEnOther UploadCode = "encounter-other"
|
||||||
|
UCSEP UploadCode = "vclaim-sep" // SEP
|
||||||
|
UCSIPP UploadCode = "vclaim-sipp" // SIPP
|
||||||
|
|
||||||
ETCPerson EntityTypeCode = "person"
|
ETCPerson EntityTypeCode = "person"
|
||||||
ETCEncounter EntityTypeCode = "encounter"
|
ETCEncounter EntityTypeCode = "encounter"
|
||||||
@@ -26,7 +29,7 @@ var validUploadCodesByEntity = map[EntityTypeCode][]UploadCode{
|
|||||||
UCPRN, UCPDL, UCPP, UCPFC,
|
UCPRN, UCPDL, UCPP, UCPFC,
|
||||||
},
|
},
|
||||||
ETCEncounter: {
|
ETCEncounter: {
|
||||||
UCSEP, UCSIPP,
|
UCSEP, UCSIPP, UCEnPatient, UCEnSupport, UcEnOther,
|
||||||
},
|
},
|
||||||
ETCMCU: {
|
ETCMCU: {
|
||||||
UCMIR,
|
UCMIR,
|
||||||
|
|||||||
@@ -0,0 +1,80 @@
|
|||||||
|
package encounter_document
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
d "github.com/karincake/dodol"
|
||||||
|
rw "github.com/karincake/risoles"
|
||||||
|
sf "github.com/karincake/semprit"
|
||||||
|
|
||||||
|
e "simrs-vx/internal/domain/main-entities/encounter-document"
|
||||||
|
u "simrs-vx/internal/use-case/main-use-case/encounter-document"
|
||||||
|
)
|
||||||
|
|
||||||
|
type myBase struct{}
|
||||||
|
|
||||||
|
var O myBase
|
||||||
|
|
||||||
|
func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
|
||||||
|
dto := e.CreateDto{}
|
||||||
|
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
res, err := u.Create(dto)
|
||||||
|
rw.DataResponse(w, res, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (obj myBase) GetList(w http.ResponseWriter, r *http.Request) {
|
||||||
|
dto := e.ReadListDto{}
|
||||||
|
sf.UrlQueryParam(&dto, *r.URL)
|
||||||
|
|
||||||
|
if dto.Encounter_Id == nil {
|
||||||
|
rw.DataResponse(w, nil, d.FieldError{
|
||||||
|
Code: "data-validation-fail",
|
||||||
|
Message: "filter encounter-id required",
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
res, err := u.ReadList(dto)
|
||||||
|
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 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
dto := e.ReadDetailDto{}
|
||||||
|
|
||||||
|
sf.UrlQueryParam(&dto, *r.URL)
|
||||||
|
dto.Id = uint16(id)
|
||||||
|
res, err := u.ReadDetail(dto)
|
||||||
|
rw.DataResponse(w, res, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
||||||
|
id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||||
|
if id <= 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
dto := e.UpdateDto{}
|
||||||
|
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
dto.Id = uint16(id)
|
||||||
|
res, err := u.Update(dto)
|
||||||
|
rw.DataResponse(w, res, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
|
||||||
|
id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||||
|
if id <= 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
dto := e.DeleteDto{}
|
||||||
|
dto.Id = uint16(id)
|
||||||
|
res, err := u.Delete(dto)
|
||||||
|
rw.DataResponse(w, res, err)
|
||||||
|
}
|
||||||
@@ -16,6 +16,7 @@ import (
|
|||||||
deviceorder "simrs-vx/internal/interface/main-handler/device-order"
|
deviceorder "simrs-vx/internal/interface/main-handler/device-order"
|
||||||
deviceorderitem "simrs-vx/internal/interface/main-handler/device-order-item"
|
deviceorderitem "simrs-vx/internal/interface/main-handler/device-order-item"
|
||||||
encounter "simrs-vx/internal/interface/main-handler/encounter"
|
encounter "simrs-vx/internal/interface/main-handler/encounter"
|
||||||
|
encounterdocument "simrs-vx/internal/interface/main-handler/encounter-document"
|
||||||
internalreference "simrs-vx/internal/interface/main-handler/internal-reference"
|
internalreference "simrs-vx/internal/interface/main-handler/internal-reference"
|
||||||
materialorder "simrs-vx/internal/interface/main-handler/material-order"
|
materialorder "simrs-vx/internal/interface/main-handler/material-order"
|
||||||
materialorderitem "simrs-vx/internal/interface/main-handler/material-order-item"
|
materialorderitem "simrs-vx/internal/interface/main-handler/material-order-item"
|
||||||
@@ -36,7 +37,6 @@ import (
|
|||||||
upload "simrs-vx/internal/interface/main-handler/upload"
|
upload "simrs-vx/internal/interface/main-handler/upload"
|
||||||
|
|
||||||
/******************** actor ********************/
|
/******************** actor ********************/
|
||||||
|
|
||||||
authpartner "simrs-vx/internal/interface/main-handler/auth-partner"
|
authpartner "simrs-vx/internal/interface/main-handler/auth-partner"
|
||||||
doctor "simrs-vx/internal/interface/main-handler/doctor"
|
doctor "simrs-vx/internal/interface/main-handler/doctor"
|
||||||
employee "simrs-vx/internal/interface/main-handler/employee"
|
employee "simrs-vx/internal/interface/main-handler/employee"
|
||||||
@@ -275,6 +275,7 @@ func SetRoutes() http.Handler {
|
|||||||
hc.RegCrud(r, "/v1/therapy-protocol", therapyprotocol.O)
|
hc.RegCrud(r, "/v1/therapy-protocol", therapyprotocol.O)
|
||||||
hc.RegCrud(r, "/v1/chemo-protocol", chemoprotocol.O)
|
hc.RegCrud(r, "/v1/chemo-protocol", chemoprotocol.O)
|
||||||
hc.RegCrud(r, "/v1/upload", upload.O)
|
hc.RegCrud(r, "/v1/upload", upload.O)
|
||||||
|
hc.RegCrud(r, "/v1/encounter-document", encounterdocument.O)
|
||||||
|
|
||||||
/******************** actor ********************/
|
/******************** actor ********************/
|
||||||
hc.RegCrud(r, "/v1/person", person.O)
|
hc.RegCrud(r, "/v1/person", person.O)
|
||||||
|
|||||||
@@ -4,13 +4,12 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
eru "simrs-vx/internal/domain/references/upload"
|
|
||||||
|
|
||||||
d "github.com/karincake/dodol"
|
d "github.com/karincake/dodol"
|
||||||
rw "github.com/karincake/risoles"
|
rw "github.com/karincake/risoles"
|
||||||
|
|
||||||
e "simrs-vx/internal/domain/main-entities/upload"
|
eru "simrs-vx/internal/domain/references/upload"
|
||||||
|
|
||||||
|
e "simrs-vx/internal/domain/main-entities/upload"
|
||||||
u "simrs-vx/internal/use-case/main-use-case/upload"
|
u "simrs-vx/internal/use-case/main-use-case/upload"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -86,4 +85,5 @@ func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
|
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ package installation
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
|
||||||
|
|
||||||
rw "github.com/karincake/risoles"
|
rw "github.com/karincake/risoles"
|
||||||
// ua "github.com/karincake/tumpeng/auth/svc"
|
// ua "github.com/karincake/tumpeng/auth/svc"
|
||||||
@@ -35,8 +34,8 @@ func (obj myBase) CreateLog(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
||||||
id := rw.ValidateString(w, "id", r.PathValue("id"))
|
id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||||
if id == "" {
|
if id <= 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -45,24 +44,22 @@ func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
val, _ := strconv.ParseUint(id, 10, 16)
|
val := uint16(id)
|
||||||
valUint := uint16(val)
|
dto.Id = &val
|
||||||
dto.Id = &valUint
|
|
||||||
|
|
||||||
res, err := u.Update(dto)
|
res, err := u.Update(dto)
|
||||||
rw.DataResponse(w, res, err)
|
rw.DataResponse(w, res, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
|
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
|
||||||
id := rw.ValidateString(w, "id", r.PathValue("id"))
|
id := rw.ValidateInt(w, "id", r.PathValue("id"))
|
||||||
if id == "" {
|
if id <= 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
dto := e.DeleteDto{}
|
dto := e.DeleteDto{}
|
||||||
val, _ := strconv.ParseUint(id, 10, 16)
|
val := uint16(id)
|
||||||
valUint := uint16(val)
|
dto.Id = &val
|
||||||
dto.Id = &valUint
|
|
||||||
|
|
||||||
res, err := u.Delete(dto)
|
res, err := u.Delete(dto)
|
||||||
rw.DataResponse(w, res, err)
|
rw.DataResponse(w, res, err)
|
||||||
|
|||||||
@@ -34,7 +34,8 @@ func SetRoutes() http.Handler {
|
|||||||
r.HandleFunc("/", home.Home)
|
r.HandleFunc("/", home.Home)
|
||||||
|
|
||||||
/******************** Source ******************/
|
/******************** Source ******************/
|
||||||
hk.GroupRoutes("/new-to-old/v1/installation", r, hk.MapHandlerFunc{
|
prefix := "/new-to-old"
|
||||||
|
hk.GroupRoutes(prefix+"/v1/installation", r, hk.MapHandlerFunc{
|
||||||
"POST /": installation.O.Create,
|
"POST /": installation.O.Create,
|
||||||
"POST /log": installation.O.CreateLog,
|
"POST /log": installation.O.CreateLog,
|
||||||
"PATCH /{id}": installation.O.Update,
|
"PATCH /{id}": installation.O.Update,
|
||||||
|
|||||||
@@ -244,13 +244,6 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
|||||||
return err
|
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 := removeUploadedFile(string(eru.ETCEncounter), *data.FilePath, &event); err != nil {
|
if err := removeUploadedFile(string(eru.ETCEncounter), *data.FilePath, &event); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -259,12 +252,6 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
mwRunner.setMwType(pu.MWTPost)
|
|
||||||
// Run post-middleware
|
|
||||||
if err := mwRunner.RunDeleteMiddleware(readDetailPostMw, &rdDto, data); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -164,29 +164,35 @@ func setEncounterDocument(input e.CreateDto, event *pl.Event, tx *gorm.DB) (*ee.
|
|||||||
Upload_Employee_Id: input.Upload_Employee_Id,
|
Upload_Employee_Id: input.Upload_Employee_Id,
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(dataUpload) > 0 {
|
if input.Type_Code == eru.UCSEP || input.Type_Code == eru.UCSIPP {
|
||||||
if err := removeUploadedFile(string(input.EntityType_Code), *dataUpload[0].FilePath, *dataUpload[0].Encounter_Id, event); err != nil {
|
if len(dataUpload) > 0 {
|
||||||
return nil, err
|
data = dataUpload[0]
|
||||||
}
|
|
||||||
|
|
||||||
// update data
|
// remove file
|
||||||
err = ue.UpdateData(ee.UpdateDto{
|
if err := removeUploadedFile(string(input.EntityType_Code), *data.FilePath, *data.Encounter_Id, event); err != nil {
|
||||||
Id: uint16(dataUpload[0].Id),
|
return nil, err
|
||||||
CreateDto: createDto}, &dataUpload[0], event, tx)
|
}
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
data = dataUpload[0]
|
// update data
|
||||||
data.FilePath = &input.FilePath
|
err = ue.UpdateData(ee.UpdateDto{
|
||||||
} else {
|
Id: uint16(data.Id),
|
||||||
// insert data
|
CreateDto: createDto}, &data, event, tx)
|
||||||
resData, err := ue.CreateData(createDto, event, tx)
|
if err != nil {
|
||||||
if err != nil {
|
return nil, err
|
||||||
return nil, err
|
}
|
||||||
|
|
||||||
|
data.FilePath = &input.FilePath
|
||||||
|
|
||||||
|
return &data, nil
|
||||||
}
|
}
|
||||||
data = *resData
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// insert data
|
||||||
|
resData, err := ue.CreateData(createDto, event, tx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
data = *resData
|
||||||
|
|
||||||
return &data, nil
|
return &data, nil
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user