improve upload done

This commit is contained in:
vanilia
2025-11-11 13:55:26 +07:00
22 changed files with 1135 additions and 202 deletions
@@ -0,0 +1,146 @@
package file_attachment
import (
"net/http"
eru "simrs-vx/internal/domain/references/upload"
"strconv"
"strings"
d "github.com/karincake/dodol"
rw "github.com/karincake/risoles"
sf "github.com/karincake/semprit"
// ua "github.com/karincake/tumpeng/auth/svc"
e "simrs-vx/internal/domain/main-entities/file-attachment"
u "simrs-vx/internal/use-case/main-use-case/file-attachement"
)
type myBase struct{}
var O myBase
func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
err := r.ParseMultipartForm(10 << 20) // 10 MB
if err != nil {
rw.DataResponse(w, nil, err)
return
}
file, header, err := r.FormFile("content")
if err != nil {
rw.DataResponse(w, nil, err)
return
}
defer file.Close()
refIDStr := r.FormValue("ref_id")
var refID *uint
if refIDStr != "" {
if id64, err := strconv.ParseUint(refIDStr, 10, 32); err == nil {
id := uint(id64)
refID = &id
}
}
employeeIdStr := r.FormValue("employee_id")
dto := e.CreateDto{
EntityType_Code: eru.EntityTypeCode(r.FormValue("entityType_code")),
Ref_Id: refID,
Type_Code: eru.UploadCode(r.FormValue("type_code")),
Name: r.FormValue("name"),
Upload_Employee_Id: &employeeIdStr,
File: file,
FileHeader: header,
Filename: header.Filename,
Size: header.Size,
MimeType: header.Header.Get("Content-Type"),
}
errs := validateCreate(dto)
if len(errs) > 0 {
rw.DataResponse(w, nil, d.FieldError{
Code: "data-validation-fail",
Message: strings.Join(errs, "\n"),
})
}
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)
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{}
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
}
err := r.ParseMultipartForm(10 << 20) // 10 MB
if err != nil {
rw.DataResponse(w, nil, err)
return
}
file, header, err := r.FormFile("content")
if err != nil {
rw.DataResponse(w, nil, err)
return
}
defer file.Close()
refIDStr := r.FormValue("ref_id")
var refID *uint
if refIDStr != "" {
if id64, err := strconv.ParseUint(refIDStr, 10, 32); err == nil {
id := uint(id64)
refID = &id
}
}
employeeIdStr := r.FormValue("employee_id")
dto := e.CreateDto{
EntityType_Code: eru.EntityTypeCode(r.FormValue("entityType_code")),
Ref_Id: refID,
Type_Code: eru.UploadCode(r.FormValue("type_code")),
Name: r.FormValue("name"),
Upload_Employee_Id: &employeeIdStr,
File: file,
FileHeader: header,
Filename: header.Filename,
Size: header.Size,
MimeType: header.Header.Get("Content-Type"),
}
res, err := u.Update(e.UpdateDto{Id: uint16(id), CreateDto: 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)
}
@@ -0,0 +1,20 @@
package file_attachment
import (
e "simrs-vx/internal/domain/main-entities/file-attachment"
)
func validateCreate(dto e.CreateDto) []string {
var errs []string
switch {
case dto.EntityType_Code == "":
errs = append(errs, "entityType_code is required")
case dto.Ref_Id == nil:
errs = append(errs, "ref_id is required")
case dto.Type_Code == "":
errs = append(errs, "type_code is required")
}
return errs
}
@@ -16,6 +16,7 @@ import (
deviceorder "simrs-vx/internal/interface/main-handler/device-order"
deviceorderitem "simrs-vx/internal/interface/main-handler/device-order-item"
encounter "simrs-vx/internal/interface/main-handler/encounter"
fileattachment "simrs-vx/internal/interface/main-handler/file-attachment"
internalreference "simrs-vx/internal/interface/main-handler/internal-reference"
materialorder "simrs-vx/internal/interface/main-handler/material-order"
materialorderitem "simrs-vx/internal/interface/main-handler/material-order-item"
@@ -268,6 +269,7 @@ func SetRoutes() http.Handler {
hc.RegCrud(r, "/v1/adm-employee-hist", admemployeehist.O)
hc.RegCrud(r, "/v1/therapy-protocol", therapyprotocol.O)
hc.RegCrud(r, "/v1/chemo-protocol", chemoprotocol.O)
hc.RegCrud(r, "POST /upload", fileattachment.O)
/******************** actor ********************/
hc.RegCrud(r, "/v1/person", person.O)
@@ -298,7 +300,6 @@ func SetRoutes() http.Handler {
"DELETE /{id}": patient.O.Delete,
"GET /search/{keyword}": patient.O.Search,
"GET /by-resident-identity": patient.O.SearchByResidentIdentityNumber,
"POST /{id}/upload": patient.O.Upload,
})
/******************** sources ********************/
@@ -11,8 +11,6 @@ import (
e "simrs-vx/internal/domain/main-entities/patient"
u "simrs-vx/internal/use-case/main-use-case/patient"
ere "simrs-vx/internal/domain/references/encounter"
d "github.com/karincake/dodol"
)
@@ -94,37 +92,3 @@ func (obj myBase) SearchByResidentIdentityNumber(w http.ResponseWriter, r *http.
res, err := u.SearchByResidentIdentityNumber(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) Upload(w http.ResponseWriter, r *http.Request) {
id := rw.ValidateInt(w, "id", r.PathValue("id"))
if id <= 0 {
return
}
err := r.ParseMultipartForm(10 << 20) // 10 MB
if err != nil {
rw.DataResponse(w, nil, err)
return
}
code := r.FormValue("code")
file, header, err := r.FormFile("content")
if err != nil {
rw.DataResponse(w, nil, err)
return
}
defer file.Close()
dto := e.UploadDto{}
dto.Id = uint(id)
dto.Code = ere.UploadCode(code)
dto.File = file
dto.FileHeader = header
dto.Filename = header.Filename
dto.Size = header.Size
dto.MimeType = header.Header.Get("Content-Type")
res, err := u.Upload(dto)
rw.DataResponse(w, res, err)
}