2023-08-16 13:17:42 +03:00
|
|
|
package handler
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"database/sql"
|
|
|
|
"errors"
|
|
|
|
"net/http"
|
|
|
|
|
2024-12-07 02:35:30 +03:00
|
|
|
httpsrv "go.unistack.org/micro-server-http/v3"
|
|
|
|
"go.unistack.org/pkgdash/internal/models"
|
|
|
|
pb "go.unistack.org/pkgdash/proto"
|
2023-08-16 13:17:42 +03:00
|
|
|
)
|
|
|
|
|
2023-08-20 14:19:57 +03:00
|
|
|
func (h *Handler) CommentCreate(ctx context.Context, req *pb.CommentCreateReq, rsp *pb.CommentCreateRsp) error {
|
2024-12-07 02:35:30 +03:00
|
|
|
h.logger.Debug(ctx, "Start AddComment")
|
2023-08-16 13:17:42 +03:00
|
|
|
|
|
|
|
err := req.Validate()
|
|
|
|
if err != nil {
|
2024-12-07 02:35:30 +03:00
|
|
|
h.logger.Error(ctx, "validation error", err)
|
2023-08-16 13:17:42 +03:00
|
|
|
httpsrv.SetRspCode(ctx, http.StatusBadRequest)
|
|
|
|
return httpsrv.SetError(NewValidationError(err))
|
|
|
|
}
|
|
|
|
|
|
|
|
var com *models.Comment
|
2023-08-20 14:19:57 +03:00
|
|
|
if com, err = h.store.CommentCreate(ctx, req); err != nil {
|
2023-08-16 13:17:42 +03:00
|
|
|
if errors.Is(err, sql.ErrNoRows) {
|
|
|
|
httpsrv.SetRspCode(ctx, http.StatusNotFound)
|
|
|
|
return httpsrv.SetError(NewNotFoundError(err))
|
|
|
|
}
|
2024-12-07 02:35:30 +03:00
|
|
|
h.logger.Error(ctx, "comment create error", err)
|
2023-08-16 13:17:42 +03:00
|
|
|
httpsrv.SetRspCode(ctx, http.StatusInternalServerError)
|
|
|
|
return httpsrv.SetError(NewInternalError(err))
|
|
|
|
}
|
|
|
|
|
|
|
|
rsp.Comment = models.NewComment(com)
|
|
|
|
|
2024-12-07 02:35:30 +03:00
|
|
|
h.logger.Debug(ctx, "Success finish addComment")
|
2023-08-16 13:17:42 +03:00
|
|
|
return nil
|
|
|
|
}
|