legalgo-BE-go/internal/api/http/logs/create_log_ads.go

87 lines
1.8 KiB
Go
Raw Normal View History

2025-03-17 22:19:17 +08:00
package logshttp
import (
logsdomain "legalgo-BE-go/internal/domain/logs"
logssvc "legalgo-BE-go/internal/services/logs"
usersvc "legalgo-BE-go/internal/services/user"
"legalgo-BE-go/internal/utilities/response"
"legalgo-BE-go/internal/utilities/utils"
"net/http"
"github.com/go-chi/chi/v5"
"github.com/go-playground/validator/v10"
2025-03-17 22:19:17 +08:00
)
func CreateLogAds(
router chi.Router,
userSvc usersvc.User,
logsSvc logssvc.Log,
validate *validator.Validate,
2025-03-17 22:19:17 +08:00
) {
2025-03-19 12:47:41 +08:00
router.Post("/logs/ads", func(w http.ResponseWriter, r *http.Request) {
2025-03-17 22:19:17 +08:00
ctx := r.Context()
var specReq logsdomain.LogsSpec
2025-03-17 22:19:17 +08:00
var spec logsdomain.LogsRequest
if err := utils.UnmarshalBody(r, &spec); err != nil {
response.RespondJsonErrorWithCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
"failed unmarshal body",
)
return
}
if err := validate.Struct(spec); err != nil {
response.RespondJsonErrorWithCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
err.(validator.ValidationErrors).Error(),
)
return
}
specReq.ContentID = spec.AdsID
userDetail, _ := utils.GetTokenDetail(r)
if userDetail.ID != "" {
specReq.UserID = &userDetail.ID
}
if ip := r.Header.Get("X-Ip-Address"); ip != "" {
specReq.IP = &ip
}
if userAgent := r.Header.Get("X-User-Agent"); userAgent != "" {
specReq.UserAgent = &userAgent
}
if err := logsSvc.CreateLogAds(specReq); err != nil {
2025-03-17 22:19:17 +08:00
response.RespondJsonErrorWithCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
err.Error(),
)
return
}
response.RespondJsonSuccess(ctx, w, struct {
Message string
}{
Message: "logs ads recorded successfully",
})
})
}