almost done, not tested yet

This commit is contained in:
dpurbosakti
2025-10-14 16:39:28 +07:00
parent d3f441dd56
commit 3e4ce7d1bf
15 changed files with 221 additions and 48 deletions
@@ -1 +1,58 @@
package vclaimsep
import (
"bytes"
"encoding/json"
"fmt"
"io"
"net/http"
e "simrs-vx/internal/domain/bpjs-entities/vclaim-sep"
ibpjs "simrs-vx/internal/infra/bpjs"
"gorm.io/gorm"
)
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))
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 vresp vclaimResponse
if err := json.Unmarshal(body, &vresp); err != nil {
return fmt.Errorf("failed to parse response JSON: %w", err)
}
msg := vresp.MetaData.Message
if err := json.Unmarshal(body, data); err != nil {
return fmt.Errorf("failed to unmarshal into VclaimSep: %w", err)
}
// Save request/response details in DTO for further use
input.VclaimSepHist.RequestPayload = string(input.RequestPayload)
input.VclaimSepHist.ResponseBody = string(body)
input.VclaimSepHist.Message = msg
input.Number = func() *string {
number := ""
if vresp.Response != nil && vresp.Response.Sep != nil {
number = vresp.Response.Sep.NoSep
}
return &number
}()
return nil
}
@@ -0,0 +1,12 @@
package vclaimsep
type vclaimResponse struct {
MetaData struct {
Message string `json:"message"`
} `json:"metaData"`
Response *struct {
Sep *struct {
NoSep string `json:"noSep"`
} `json:"sep"`
} `json:"response"`
}