product_create.go 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. package handler
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "github.com/sirupsen/logrus"
  5. log "github.com/sirupsen/logrus"
  6. "youngee_m_api/consts"
  7. "youngee_m_api/db"
  8. "youngee_m_api/model/http_model"
  9. "youngee_m_api/service"
  10. "youngee_m_api/util"
  11. )
  12. func WrapCreateProductHandler(ctx *gin.Context) {
  13. handler := newCreateProductHandler(ctx)
  14. BaseRun(handler)
  15. }
  16. func newCreateProductHandler(ctx *gin.Context) *CreateProductHandler {
  17. return &CreateProductHandler{
  18. req: http_model.NewCreateProductRequest(),
  19. resp: http_model.NewCreateProductResponse(),
  20. ctx: ctx,
  21. }
  22. }
  23. type CreateProductHandler struct {
  24. req *http_model.CreateProductRequest
  25. resp *http_model.CommonResponse
  26. ctx *gin.Context
  27. }
  28. func (h *CreateProductHandler) getRequest() interface{} {
  29. return h.req
  30. }
  31. func (h *CreateProductHandler) getContext() *gin.Context {
  32. return h.ctx
  33. }
  34. func (h *CreateProductHandler) getResponse() interface{} {
  35. return h.resp
  36. }
  37. func (h *CreateProductHandler) run() {
  38. data := http_model.CreateProductRequest{}
  39. data = *h.req
  40. enterpriseID := db.GetEnterpriseIDByProductID(h.ctx, h.req.ProductId)
  41. //根据品牌名和商品名查询商品是否存在,若存在则更新,否则新增
  42. product, err := service.Product.FindByID(h.ctx, data.ProductId)
  43. if err != nil {
  44. logrus.Errorf("[CreateProductHandler] call FindByID err:%+v\n", err)
  45. util.HandlerPackErrorResp(h.resp, consts.ErrorInternal, "")
  46. log.Info("CreateProduct fail,req:%+v", h.req)
  47. return
  48. } else {
  49. if product != nil {
  50. // 该商品存在,更新
  51. data.ProductId = product.ProductID
  52. res, err := service.Product.Update(h.ctx, data, enterpriseID)
  53. if err != nil {
  54. logrus.Errorf("[CreateProductHandler] call Update err:%+v\n", err)
  55. util.HandlerPackErrorResp(h.resp, consts.ErrorInternal, "")
  56. log.Info("CreateProduct fail,req:%+v", h.req)
  57. return
  58. }
  59. h.resp.Message = "成功更新商品信息"
  60. h.resp.Data = res
  61. } else {
  62. // 商品不存在,新增
  63. res, err := service.Product.Create(h.ctx, data, enterpriseID)
  64. if err != nil {
  65. logrus.Errorf("[CreateProductHandler] call Create err:%+v\n", err)
  66. util.HandlerPackErrorResp(h.resp, consts.ErrorInternal, "")
  67. log.Info("CreateProduct fail,req:%+v", h.req)
  68. return
  69. }
  70. h.resp.Message = "成功新增商品信息"
  71. h.resp.Data = res
  72. }
  73. }
  74. }
  75. func (h *CreateProductHandler) checkParam() error {
  76. return nil
  77. }