narasiahli-be/app/module/activity_logs/controller/activity_logs.controller.go

245 lines
7.5 KiB
Go

package controller
import (
"narasi-ahli-be/app/module/activity_logs/request"
"narasi-ahli-be/app/module/activity_logs/service"
"narasi-ahli-be/utils/paginator"
utilRes "narasi-ahli-be/utils/response"
utilVal "narasi-ahli-be/utils/validator"
"strconv"
"strings"
"github.com/gofiber/fiber/v2"
"github.com/rs/zerolog"
)
type activityLogsController struct {
activityLogsService service.ActivityLogsService
Log zerolog.Logger
}
type ActivityLogsController interface {
All(c *fiber.Ctx) error
Show(c *fiber.Ctx) error
Save(c *fiber.Ctx) error
Update(c *fiber.Ctx) error
Delete(c *fiber.Ctx) error
GetActivityStats(c *fiber.Ctx) error
}
func NewActivityLogsController(activityLogsService service.ActivityLogsService, log zerolog.Logger) ActivityLogsController {
return &activityLogsController{
activityLogsService: activityLogsService,
Log: log,
}
}
// All get all ActivityLogs
// @Summary Get all ActivityLogs
// @Description API for getting all ActivityLogs
// @Tags ActivityLogs
// @Security Bearer
// @Param req query request.ActivityLogsQueryRequest false "query parameters"
// @Param req query paginator.Pagination false "pagination parameters"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /activity-logs [get]
func (_i *activityLogsController) All(c *fiber.Ctx) error {
paginate, err := paginator.Paginate(c)
if err != nil {
return err
}
reqContext := request.ActivityLogsQueryRequestContext{
ActivityTypeId: c.Query("activityTypeId"),
Url: c.Query("url"),
ArticleId: c.Query("articleId"),
UserId: c.Query("userId"),
}
req := reqContext.ToParamRequest()
req.Pagination = paginate
activityLogsData, paging, err := _i.activityLogsService.All(req)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"ActivityLogs list successfully retrieved"},
Data: activityLogsData,
Meta: paging,
})
}
// Show get one ActivityLogs
// @Summary Get one ActivityLogs
// @Description API for getting one ActivityLogs
// @Tags ActivityLogs
// @Security Bearer
// @Param id path int true "ActivityLogs ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /activity-logs/detail/{id} [get]
func (_i *activityLogsController) Show(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
activityLogsData, err := _i.activityLogsService.Show(uint(id))
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"ActivityLogs successfully retrieved"},
Data: activityLogsData,
})
}
// Save create ActivityLogs
// @Summary Create ActivityLogs
// @Description API for create ActivityLogs
// @Tags ActivityLogs
// @Security Bearer
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
// @Param Authorization header string false "Insert your access token" default(Bearer <Add access token here>)
// @Param payload body request.ActivityLogsCreateRequest true "Required payload"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /activity-logs [post]
func (_i *activityLogsController) Save(c *fiber.Ctx) error {
req := new(request.ActivityLogsCreateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
var authToken *string
getTokenFromHeader := c.Get("Authorization")
if getTokenFromHeader == "" {
authToken = nil
} else {
authToken = &getTokenFromHeader
}
visitorIp := GetVisitorIP(c)
req.VisitorIp = &visitorIp
dataResult, err := _i.activityLogsService.Save(*req, authToken)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"ActivityLogs successfully created"},
Data: dataResult,
})
}
// Update update ActivityLogs
// @Summary update ActivityLogs
// @Description API for update ActivityLogs
// @Tags ActivityLogs
// @Security Bearer
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
// @Param payload body request.ActivityLogsUpdateRequest true "Required payload"
// @Param id path int true "ActivityLogs ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /activity-logs/{id} [put]
func (_i *activityLogsController) Update(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
req := new(request.ActivityLogsUpdateRequest)
if err := utilVal.ParseAndValidate(c, req); err != nil {
return err
}
err = _i.activityLogsService.Update(uint(id), *req)
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"ActivityLogs successfully updated"},
})
}
// Delete delete ActivityLogs
// @Summary delete ActivityLogs
// @Description API for delete ActivityLogs
// @Tags ActivityLogs
// @Security Bearer
// @Param X-Csrf-Token header string true "Insert the X-Csrf-Token"
// @Param id path int true "ActivityLogs ID"
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /activity-logs/{id} [delete]
func (_i *activityLogsController) Delete(c *fiber.Ctx) error {
id, err := strconv.ParseUint(c.Params("id"), 10, 0)
if err != nil {
return err
}
err = _i.activityLogsService.Delete(uint(id))
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"ActivityLogs successfully deleted"},
})
}
// GetActivityStats get activity stats ActivityLogs
// @Summary Get activity stats ActivityLogs
// @Description API for get activity stats ActivityLogs
// @Tags ActivityLogs
// @Security Bearer
// @Success 200 {object} response.Response
// @Failure 400 {object} response.BadRequestError
// @Failure 401 {object} response.UnauthorizedError
// @Failure 500 {object} response.InternalServerError
// @Router /activity-logs/statistics [get]
func (_i *activityLogsController) GetActivityStats(c *fiber.Ctx) error {
_i.Log.Info().Interface("GetActivityStats", "checker controller").Msg("")
activityStatsData, err := _i.activityLogsService.GetActivityStats()
if err != nil {
return err
}
return utilRes.Resp(c, utilRes.Response{
Success: true,
Messages: utilRes.Messages{"ActivityLogs Stats successfully retrieved"},
Data: activityStatsData,
})
}
func GetVisitorIP(c *fiber.Ctx) string {
ip := c.Get("X-Forwarded-For")
if ip == "" {
ip = c.IP()
}
if strings.Contains(ip, ":") {
ip = strings.Split(ip, ":")[0]
}
return ip
}