Banyak perubahan Tool bpjs
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
// Code generated by generate-dynamic-handler.go; DO NOT EDIT.
|
||||
// Generated at: 2025-08-29 13:02:57
|
||||
// Generated at: 2025-09-01 11:57:39
|
||||
// Service: VClaim (vclaim)
|
||||
// Description: BPJS VClaim service for eligibility and SEP management
|
||||
|
||||
@@ -12,7 +12,6 @@ import (
|
||||
|
||||
"api-service/internal/config"
|
||||
"api-service/internal/models/reference"
|
||||
services "api-service/internal/services/bpjs"
|
||||
"api-service/pkg/logger"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
@@ -20,9 +19,22 @@ import (
|
||||
"github.com/google/uuid"
|
||||
)
|
||||
|
||||
// VClaimService defines VClaim service interface
|
||||
type VClaimService interface {
|
||||
GetPeserta(ctx context.Context, nokartu string) (*reference.PesertaData, error)
|
||||
|
||||
GetSep(ctx context.Context, nosep string) (*reference.SepData, error)
|
||||
|
||||
CreateSep(ctx context.Context, req *reference.SepRequest) (*reference.SepData, error)
|
||||
|
||||
UpdateSep(ctx context.Context, nosep string, req *reference.SepRequest) (*reference.SepData, error)
|
||||
|
||||
DeleteSep(ctx context.Context, nosep string) error
|
||||
}
|
||||
|
||||
// VClaimHandler handles VClaim BPJS services
|
||||
type VClaimHandler struct {
|
||||
service reference.VClaimService
|
||||
service VClaimService
|
||||
validator *validator.Validate
|
||||
logger logger.Logger
|
||||
config config.BpjsConfig
|
||||
@@ -36,11 +48,9 @@ type VClaimHandlerConfig struct {
|
||||
}
|
||||
|
||||
// NewVClaimHandler creates a new VClaimHandler
|
||||
func NewVClaimHandler(cfg VClaimHandlerConfig) *VClaimHandler {
|
||||
baseService := services.NewService(cfg.BpjsConfig)
|
||||
adapter := services.NewVClaimAdapter(baseService)
|
||||
func NewVClaimHandler(cfg VClaimHandlerConfig, service VClaimService) *VClaimHandler {
|
||||
return &VClaimHandler{
|
||||
service: adapter,
|
||||
service: service,
|
||||
validator: cfg.Validator,
|
||||
logger: cfg.Logger,
|
||||
config: cfg.BpjsConfig,
|
||||
@@ -62,7 +72,7 @@ func NewVClaimHandler(cfg VClaimHandlerConfig) *VClaimHandler {
|
||||
// @Failure 500 {object} reference.ErrorResponse
|
||||
// @Router /peserta/:nokartu [get]
|
||||
|
||||
func (h *VClaimHandler) GetPESERTA(c *gin.Context) {
|
||||
func (h *VClaimHandler) GetPeserta(c *gin.Context) {
|
||||
ctx, cancel := context.WithTimeout(c.Request.Context(), 30*time.Second)
|
||||
defer cancel()
|
||||
|
||||
@@ -101,7 +111,9 @@ func (h *VClaimHandler) GetPESERTA(c *gin.Context) {
|
||||
var response reference.PesertaResponse
|
||||
|
||||
result, err := h.service.GetPeserta(ctx, nokartu)
|
||||
|
||||
if err != nil {
|
||||
|
||||
h.logger.Error("Failed to get Peserta", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
@@ -115,7 +127,7 @@ func (h *VClaimHandler) GetPESERTA(c *gin.Context) {
|
||||
return
|
||||
}
|
||||
|
||||
// Assign result to response
|
||||
// Ensure response has proper fields
|
||||
response.Status = "success"
|
||||
response.RequestID = requestID
|
||||
response.Data = result
|
||||
@@ -132,12 +144,12 @@ func (h *VClaimHandler) GetPESERTA(c *gin.Context) {
|
||||
|
||||
// @Param nosep path string true "nosep"
|
||||
|
||||
// @Success 200 {object} reference.SEPResponse
|
||||
// @Success 200 {object} reference.SepResponse
|
||||
// @Failure 400 {object} reference.ErrorResponse
|
||||
// @Failure 500 {object} reference.ErrorResponse
|
||||
// @Router /sep/:nosep [get]
|
||||
|
||||
func (h *VClaimHandler) GetSEP(c *gin.Context) {
|
||||
func (h *VClaimHandler) GetSep(c *gin.Context) {
|
||||
ctx, cancel := context.WithTimeout(c.Request.Context(), 30*time.Second)
|
||||
defer cancel()
|
||||
|
||||
@@ -173,10 +185,12 @@ func (h *VClaimHandler) GetSEP(c *gin.Context) {
|
||||
}
|
||||
|
||||
// Call service method
|
||||
var response reference.SEPResponse
|
||||
var response reference.SepResponse
|
||||
|
||||
result, err := h.service.GetSep(ctx, nosep)
|
||||
|
||||
result, err := h.service.GetSEP(ctx, nosep)
|
||||
if err != nil {
|
||||
|
||||
h.logger.Error("Failed to get Sep", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
@@ -190,7 +204,7 @@ func (h *VClaimHandler) GetSEP(c *gin.Context) {
|
||||
return
|
||||
}
|
||||
|
||||
// Assign result to response
|
||||
// Ensure response has proper fields
|
||||
response.Status = "success"
|
||||
response.RequestID = requestID
|
||||
response.Data = result
|
||||
@@ -205,13 +219,13 @@ func (h *VClaimHandler) GetSEP(c *gin.Context) {
|
||||
// @Accept json
|
||||
// @Produce json
|
||||
|
||||
// @Param request body reference.SEPRequest true "Sep data"
|
||||
// @Success 201 {object} reference.SEPResponse
|
||||
// @Param request body reference.SepRequest true "Sep data"
|
||||
// @Success 201 {object} reference.SepResponse
|
||||
// @Failure 400 {object} reference.ErrorResponse
|
||||
// @Failure 500 {object} reference.ErrorResponse
|
||||
// @Router /sep [post]
|
||||
|
||||
func (h *VClaimHandler) CreateSEP(c *gin.Context) {
|
||||
func (h *VClaimHandler) CreateSep(c *gin.Context) {
|
||||
ctx, cancel := context.WithTimeout(c.Request.Context(), 30*time.Second)
|
||||
defer cancel()
|
||||
|
||||
@@ -225,7 +239,7 @@ func (h *VClaimHandler) CreateSEP(c *gin.Context) {
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
var req reference.SEPRequest
|
||||
var req reference.SepRequest
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
|
||||
h.logger.Error("Invalid request body", map[string]interface{}{
|
||||
@@ -258,9 +272,10 @@ func (h *VClaimHandler) CreateSEP(c *gin.Context) {
|
||||
}
|
||||
|
||||
// Call service method
|
||||
var response reference.SEPResponse
|
||||
result, err := h.service.CreateSEP(ctx, &req)
|
||||
var response reference.SepResponse
|
||||
result, err := h.service.CreateSep(ctx, &req)
|
||||
if err != nil {
|
||||
|
||||
h.logger.Error("Failed to create Sep", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
@@ -274,9 +289,179 @@ func (h *VClaimHandler) CreateSEP(c *gin.Context) {
|
||||
return
|
||||
}
|
||||
|
||||
// Assign result to response
|
||||
// Ensure response has proper fields
|
||||
response.Status = "success"
|
||||
response.RequestID = requestID
|
||||
response.Data = result
|
||||
c.JSON(http.StatusCreated, response)
|
||||
}
|
||||
|
||||
// UpdateSEP updates existing Sep
|
||||
|
||||
// @Summary Update Sep
|
||||
// @Description Manage SEP (Surat Eligibilitas Peserta)
|
||||
// @Tags vclaim,sep
|
||||
// @Accept json
|
||||
// @Produce json
|
||||
|
||||
// @Param nosep path string true "nosep"
|
||||
|
||||
// @Param request body reference.SepRequest true "Sep data"
|
||||
// @Success 200 {object} reference.SepResponse
|
||||
// @Failure 400 {object} reference.ErrorResponse
|
||||
// @Failure 500 {object} reference.ErrorResponse
|
||||
// @Router /sep/:nosep [put]
|
||||
|
||||
func (h *VClaimHandler) UpdateSep(c *gin.Context) {
|
||||
ctx, cancel := context.WithTimeout(c.Request.Context(), 30*time.Second)
|
||||
defer cancel()
|
||||
|
||||
requestID := c.GetHeader("X-Request-ID")
|
||||
if requestID == "" {
|
||||
requestID = uuid.New().String()
|
||||
c.Header("X-Request-ID", requestID)
|
||||
}
|
||||
|
||||
h.logger.Info("Processing UpdateSep request", map[string]interface{}{
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
nosep := c.Param("nosep")
|
||||
if nosep == "" {
|
||||
|
||||
h.logger.Error("Missing required parameter nosep", map[string]interface{}{
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
c.JSON(http.StatusBadRequest, reference.ErrorResponse{
|
||||
Status: "error",
|
||||
Message: "Missing required parameter nosep",
|
||||
RequestID: requestID,
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
var req reference.SepRequest
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
|
||||
h.logger.Error("Invalid request body", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
c.JSON(http.StatusBadRequest, reference.ErrorResponse{
|
||||
Status: "error",
|
||||
Message: "Invalid request body: " + err.Error(),
|
||||
RequestID: requestID,
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
// Validate request
|
||||
if err := h.validator.Struct(&req); err != nil {
|
||||
|
||||
h.logger.Error("Validation failed", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
c.JSON(http.StatusBadRequest, reference.ErrorResponse{
|
||||
Status: "error",
|
||||
Message: "Validation failed: " + err.Error(),
|
||||
RequestID: requestID,
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
// Call service method
|
||||
var response reference.SepResponse
|
||||
|
||||
result, err := h.service.UpdateSep(ctx, nosep, &req)
|
||||
|
||||
if err != nil {
|
||||
|
||||
h.logger.Error("Failed to update Sep", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
c.JSON(http.StatusInternalServerError, reference.ErrorResponse{
|
||||
Status: "error",
|
||||
Message: "Internal server error",
|
||||
RequestID: requestID,
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
// Ensure response has proper fields
|
||||
response.Status = "success"
|
||||
response.RequestID = requestID
|
||||
response.Data = result
|
||||
c.JSON(http.StatusOK, response)
|
||||
}
|
||||
|
||||
// DeleteSEP deletes existing Sep
|
||||
|
||||
// @Summary Delete Sep
|
||||
// @Description Manage SEP (Surat Eligibilitas Peserta)
|
||||
// @Tags vclaim,sep
|
||||
// @Accept json
|
||||
// @Produce json
|
||||
|
||||
// @Param nosep path string true "nosep"
|
||||
|
||||
// @Success 204 {object} nil
|
||||
// @Failure 400 {object} reference.ErrorResponse
|
||||
// @Failure 500 {object} reference.ErrorResponse
|
||||
// @Router /sep/:nosep [delete]
|
||||
|
||||
func (h *VClaimHandler) DeleteSep(c *gin.Context) {
|
||||
ctx, cancel := context.WithTimeout(c.Request.Context(), 30*time.Second)
|
||||
defer cancel()
|
||||
|
||||
requestID := c.GetHeader("X-Request-ID")
|
||||
if requestID == "" {
|
||||
requestID = uuid.New().String()
|
||||
c.Header("X-Request-ID", requestID)
|
||||
}
|
||||
|
||||
h.logger.Info("Processing DeleteSep request", map[string]interface{}{
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
nosep := c.Param("nosep")
|
||||
if nosep == "" {
|
||||
|
||||
h.logger.Error("Missing required parameter nosep", map[string]interface{}{
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
c.JSON(http.StatusBadRequest, reference.ErrorResponse{
|
||||
Status: "error",
|
||||
Message: "Missing required parameter nosep",
|
||||
RequestID: requestID,
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
// Call service method
|
||||
|
||||
err := h.service.DeleteSep(ctx, nosep)
|
||||
|
||||
if err != nil {
|
||||
|
||||
h.logger.Error("Failed to delete Sep", map[string]interface{}{
|
||||
"error": err.Error(),
|
||||
"request_id": requestID,
|
||||
})
|
||||
|
||||
c.JSON(http.StatusInternalServerError, reference.ErrorResponse{
|
||||
Status: "error",
|
||||
Message: "Internal server error",
|
||||
RequestID: requestID,
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
c.Status(http.StatusNoContent)
|
||||
}
|
||||
|
||||
@@ -1,29 +1,27 @@
|
||||
// internal/models/reference/services.go
|
||||
package reference
|
||||
|
||||
import "context"
|
||||
|
||||
// VClaimService defines VClaim service interface
|
||||
type VClaimService interface {
|
||||
GetPeserta(ctx context.Context, noKartu string) (*PesertaData, error)
|
||||
CreateSEP(ctx context.Context, req *SEPRequest) (*SEPData, error)
|
||||
GetSEP(ctx context.Context, noSep string) (*SEPData, error)
|
||||
UpdateSEP(ctx context.Context, noSep string, req *SEPRequest) (*SEPData, error)
|
||||
DeleteSEP(ctx context.Context, noSep string) error
|
||||
GetRujukan(ctx context.Context, noRujukan string) (*RujukanData, error)
|
||||
}
|
||||
// type VClaimService interface {
|
||||
// GetPESERTA(ctx context.Context, nokartu string) (*PesertaData, error)
|
||||
// CreateSEP(ctx context.Context, req *SEPRequest) (*SEPData, error)
|
||||
// GetSEP(ctx context.Context, nosep string) (*SEPData, error)
|
||||
// UpdateSEP(ctx context.Context, nosep string, req *SEPRequest) (*SEPData, error)
|
||||
// DeleteSEP(ctx context.Context, nosep string) error
|
||||
// GetRujukan(ctx context.Context, norujukan string) (*RujukanData, error)
|
||||
// }
|
||||
|
||||
// EClaimService defines EClaim service interface
|
||||
type EClaimService interface {
|
||||
CreateKlaim(ctx context.Context, req *KlaimRequest) (*KlaimResponseData, error)
|
||||
GetKlaim(ctx context.Context, noKlaim string) (*KlaimResponseData, error)
|
||||
UpdateKlaim(ctx context.Context, noKlaim string, req *KlaimRequest) (*KlaimResponseData, error)
|
||||
ProcessGrouper(ctx context.Context, req *GrouperRequest) (*GrouperResult, error)
|
||||
}
|
||||
// // EClaimService defines EClaim service interface
|
||||
// type EClaimService interface {
|
||||
// CreateKlaim(ctx context.Context, req *KlaimRequest) (*KlaimResponseData, error)
|
||||
// GetKlaim(ctx context.Context, noKlaim string) (*KlaimResponseData, error)
|
||||
// UpdateKlaim(ctx context.Context, noKlaim string, req *KlaimRequest) (*KlaimResponseData, error)
|
||||
// ProcessGrouper(ctx context.Context, req *GrouperRequest) (*GrouperResult, error)
|
||||
// }
|
||||
|
||||
// AplicareService defines Aplicare service interface
|
||||
type AplicareService interface {
|
||||
GetReferensi(ctx context.Context, req *ReferensiRequest) ([]ReferensiData, *PaginationResponse, error)
|
||||
GetMonitoring(ctx context.Context, req *MonitoringRequest) ([]MonitoringData, *MonitoringSummary, *PaginationResponse, error)
|
||||
CreateMonitoring(ctx context.Context, req *MonitoringRequest) error
|
||||
}
|
||||
// // AplicareService defines Aplicare service interface
|
||||
// type AplicareService interface {
|
||||
// GetReferensi(ctx context.Context, req *ReferensiRequest) ([]ReferensiData, *PaginationResponse, error)
|
||||
// GetMonitoring(ctx context.Context, req *MonitoringRequest) ([]MonitoringData, *MonitoringSummary, *PaginationResponse, error)
|
||||
// CreateMonitoring(ctx context.Context, req *MonitoringRequest) error
|
||||
// }
|
||||
|
||||
@@ -54,7 +54,7 @@ type PesertaResponse struct {
|
||||
// === SEP (Surat Eligibilitas Peserta) MODELS ===
|
||||
|
||||
// SEPRequest represents SEP creation/update request
|
||||
type SEPRequest struct {
|
||||
type SepRequest struct {
|
||||
BaseRequest
|
||||
NoKartu string `json:"noKartu" validate:"required"`
|
||||
TglSep string `json:"tglSep" validate:"required"`
|
||||
@@ -62,7 +62,7 @@ type SEPRequest struct {
|
||||
JnsPelayanan string `json:"jnsPelayanan" validate:"required,oneof=1 2"`
|
||||
KlsRawat string `json:"klsRawat" validate:"required,oneof=1 2 3"`
|
||||
NoMR string `json:"noMR" validate:"required"`
|
||||
Rujukan *SEPRujukan `json:"rujukan"`
|
||||
Rujukan *SepRujukan `json:"rujukan"`
|
||||
Catatan string `json:"catatan,omitempty"`
|
||||
Diagnosa string `json:"diagnosa" validate:"required"`
|
||||
PoliTujuan string `json:"poli" validate:"required"`
|
||||
@@ -71,7 +71,7 @@ type SEPRequest struct {
|
||||
}
|
||||
|
||||
// SEPRujukan represents rujukan information in SEP
|
||||
type SEPRujukan struct {
|
||||
type SepRujukan struct {
|
||||
AsalRujukan string `json:"asalRujukan" validate:"required,oneof=1 2"`
|
||||
TglRujukan string `json:"tglRujukan" validate:"required"`
|
||||
NoRujukan string `json:"noRujukan" validate:"required"`
|
||||
@@ -79,14 +79,14 @@ type SEPRujukan struct {
|
||||
}
|
||||
|
||||
// SEPData represents SEP response data
|
||||
type SEPData struct {
|
||||
type SepData struct {
|
||||
NoSep string `json:"noSep"`
|
||||
TglSep string `json:"tglSep"`
|
||||
JnsPelayanan string `json:"jnsPelayanan"`
|
||||
PoliTujuan string `json:"poli"`
|
||||
KlsRawat string `json:"klsRawat"`
|
||||
NoMR string `json:"noMR"`
|
||||
Rujukan SEPRujukan `json:"rujukan"`
|
||||
Rujukan SepRujukan `json:"rujukan"`
|
||||
Catatan string `json:"catatan"`
|
||||
Diagnosa string `json:"diagnosa"`
|
||||
Peserta PesertaData `json:"peserta"`
|
||||
@@ -99,9 +99,9 @@ type SEPData struct {
|
||||
}
|
||||
|
||||
// SEPResponse represents SEP API response
|
||||
type SEPResponse struct {
|
||||
type SepResponse struct {
|
||||
BaseResponse
|
||||
Data *SEPData `json:"data,omitempty"`
|
||||
Data *SepData `json:"data,omitempty"`
|
||||
}
|
||||
|
||||
// === RUJUKAN MODELS ===
|
||||
|
||||
@@ -1,187 +0,0 @@
|
||||
package services
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
|
||||
"api-service/internal/models/reference"
|
||||
)
|
||||
|
||||
// VClaimAdapter adapts the generic VClaimService to implement the reference.VClaimService interface
|
||||
type VClaimAdapter struct {
|
||||
service VClaimService
|
||||
}
|
||||
|
||||
// NewVClaimAdapter creates a new VClaimAdapter
|
||||
func NewVClaimAdapter(service VClaimService) *VClaimAdapter {
|
||||
return &VClaimAdapter{
|
||||
service: service,
|
||||
}
|
||||
}
|
||||
|
||||
// Get implements VClaimService.Get
|
||||
func (a *VClaimAdapter) Get(ctx context.Context, endpoint string, result interface{}) error {
|
||||
return a.service.Get(ctx, endpoint, result)
|
||||
}
|
||||
|
||||
// Post implements VClaimService.Post
|
||||
func (a *VClaimAdapter) Post(ctx context.Context, endpoint string, payload interface{}, result interface{}) error {
|
||||
return a.service.Post(ctx, endpoint, payload, result)
|
||||
}
|
||||
|
||||
// Put implements VClaimService.Put
|
||||
func (a *VClaimAdapter) Put(ctx context.Context, endpoint string, payload interface{}, result interface{}) error {
|
||||
return a.service.Put(ctx, endpoint, payload, result)
|
||||
}
|
||||
|
||||
// Delete implements VClaimService.Delete
|
||||
func (a *VClaimAdapter) Delete(ctx context.Context, endpoint string, result interface{}) error {
|
||||
return a.service.Delete(ctx, endpoint, result)
|
||||
}
|
||||
|
||||
// GetRawResponse implements VClaimService.GetRawResponse
|
||||
func (a *VClaimAdapter) GetRawResponse(ctx context.Context, endpoint string) (*ResponDTOVclaim, error) {
|
||||
return a.service.GetRawResponse(ctx, endpoint)
|
||||
}
|
||||
|
||||
// PostRawResponse implements VClaimService.PostRawResponse
|
||||
func (a *VClaimAdapter) PostRawResponse(ctx context.Context, endpoint string, payload interface{}) (*ResponDTOVclaim, error) {
|
||||
return a.service.PostRawResponse(ctx, endpoint, payload)
|
||||
}
|
||||
|
||||
// GetPeserta implements reference.VClaimService.GetPeserta
|
||||
func (a *VClaimAdapter) GetPeserta(ctx context.Context, noKartu string) (*reference.PesertaData, error) {
|
||||
var response struct {
|
||||
MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
} `json:"metaData"`
|
||||
Response reference.PesertaData `json:"response"`
|
||||
}
|
||||
|
||||
endpoint := fmt.Sprintf("/Peserta/%s", noKartu)
|
||||
err := a.service.Get(ctx, endpoint, &response)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if response.MetaData.Code != "200" {
|
||||
return nil, fmt.Errorf("BPJS API error: %s - %s", response.MetaData.Code, response.MetaData.Message)
|
||||
}
|
||||
|
||||
return &response.Response, nil
|
||||
}
|
||||
|
||||
// GetSEP implements reference.VClaimService.GetSEP
|
||||
func (a *VClaimAdapter) GetSEP(ctx context.Context, noSep string) (*reference.SEPData, error) {
|
||||
var response struct {
|
||||
MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
} `json:"metaData"`
|
||||
Response reference.SEPData `json:"response"`
|
||||
}
|
||||
|
||||
endpoint := fmt.Sprintf("/SEP/%s", noSep)
|
||||
err := a.service.Get(ctx, endpoint, &response)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if response.MetaData.Code != "200" {
|
||||
return nil, fmt.Errorf("BPJS API error: %s - %s", response.MetaData.Code, response.MetaData.Message)
|
||||
}
|
||||
|
||||
return &response.Response, nil
|
||||
}
|
||||
|
||||
// CreateSEP implements reference.VClaimService.CreateSEP
|
||||
func (a *VClaimAdapter) CreateSEP(ctx context.Context, req *reference.SEPRequest) (*reference.SEPData, error) {
|
||||
var response struct {
|
||||
MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
} `json:"metaData"`
|
||||
Response reference.SEPData `json:"response"`
|
||||
}
|
||||
|
||||
endpoint := "/SEP/2.0/insert"
|
||||
err := a.service.Post(ctx, endpoint, req, &response)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if response.MetaData.Code != "200" {
|
||||
return nil, fmt.Errorf("BPJS API error: %s - %s", response.MetaData.Code, response.MetaData.Message)
|
||||
}
|
||||
|
||||
return &response.Response, nil
|
||||
}
|
||||
|
||||
// UpdateSEP implements reference.VClaimService.UpdateSEP
|
||||
func (a *VClaimAdapter) UpdateSEP(ctx context.Context, noSep string, req *reference.SEPRequest) (*reference.SEPData, error) {
|
||||
var response struct {
|
||||
MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
} `json:"metaData"`
|
||||
Response reference.SEPData `json:"response"`
|
||||
}
|
||||
|
||||
endpoint := fmt.Sprintf("/SEP/%s", noSep)
|
||||
err := a.service.Put(ctx, endpoint, req, &response)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if response.MetaData.Code != "200" {
|
||||
return nil, fmt.Errorf("BPJS API error: %s - %s", response.MetaData.Code, response.MetaData.Message)
|
||||
}
|
||||
|
||||
return &response.Response, nil
|
||||
}
|
||||
|
||||
// DeleteSEP implements reference.VClaimService.DeleteSEP
|
||||
func (a *VClaimAdapter) DeleteSEP(ctx context.Context, noSep string) error {
|
||||
var response struct {
|
||||
MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
} `json:"metaData"`
|
||||
}
|
||||
|
||||
endpoint := fmt.Sprintf("/SEP/%s", noSep)
|
||||
err := a.service.Delete(ctx, endpoint, &response)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if response.MetaData.Code != "200" {
|
||||
return fmt.Errorf("BPJS API error: %s - %s", response.MetaData.Code, response.MetaData.Message)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// GetRujukan implements reference.VClaimService.GetRujukan
|
||||
func (a *VClaimAdapter) GetRujukan(ctx context.Context, noRujukan string) (*reference.RujukanData, error) {
|
||||
var response struct {
|
||||
MetaData struct {
|
||||
Code string `json:"code"`
|
||||
Message string `json:"message"`
|
||||
} `json:"metaData"`
|
||||
Response reference.RujukanData `json:"response"`
|
||||
}
|
||||
|
||||
endpoint := fmt.Sprintf("/Rujukan/%s", noRujukan)
|
||||
err := a.service.Get(ctx, endpoint, &response)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if response.MetaData.Code != "200" {
|
||||
return nil, fmt.Errorf("BPJS API error: %s - %s", response.MetaData.Code, response.MetaData.Message)
|
||||
}
|
||||
|
||||
return &response.Response, nil
|
||||
}
|
||||
Reference in New Issue
Block a user