Banyak perubahan Tool bpjs

This commit is contained in:
2025-09-01 11:58:34 +07:00
parent 3951fd87a7
commit c154f96621
9 changed files with 2104 additions and 65 deletions

View File

@@ -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)
}