logistics_create.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. package handler
  2. import (
  3. "fmt"
  4. "youngee_m_api/consts"
  5. "youngee_m_api/model/http_model"
  6. "youngee_m_api/service"
  7. "youngee_m_api/util"
  8. "github.com/gin-gonic/gin"
  9. "github.com/sirupsen/logrus"
  10. log "github.com/sirupsen/logrus"
  11. )
  12. func WrapCreateLogisticsHandler(ctx *gin.Context) {
  13. handler := newCreateLogisticsHandler(ctx)
  14. BaseRun(handler)
  15. }
  16. func newCreateLogisticsHandler(ctx *gin.Context) *CreateLogisticsHandler {
  17. return &CreateLogisticsHandler{
  18. req: http_model.NewCreateLogisticsRequest(),
  19. resp: http_model.NewCreateLogisticsResponse(),
  20. ctx: ctx,
  21. }
  22. }
  23. type CreateLogisticsHandler struct {
  24. req *http_model.CreateLogisticsRequest
  25. resp *http_model.CommonResponse
  26. ctx *gin.Context
  27. }
  28. func (h *CreateLogisticsHandler) getRequest() interface{} {
  29. return h.req
  30. }
  31. func (h *CreateLogisticsHandler) getContext() *gin.Context {
  32. return h.ctx
  33. }
  34. func (h *CreateLogisticsHandler) getResponse() interface{} {
  35. return h.resp
  36. }
  37. func (h *CreateLogisticsHandler) run() {
  38. data := http_model.CreateLogisticsRequest{}
  39. data = *h.req
  40. isUpdate := data.IsUpdate
  41. if isUpdate == 0 {
  42. fmt.Println("Create in")
  43. res, err := service.Logistics.Create(h.ctx, data)
  44. if err != nil {
  45. logrus.Errorf("[CreateLogisticsHandler] call Create err:%+v\n", err)
  46. util.HandlerPackErrorResp(h.resp, consts.ErrorInternal, "")
  47. log.Info("CreateProject fail,req:%+v", h.req)
  48. return
  49. }
  50. h.resp.Message = "成功添加物流信息"
  51. h.resp.Data = res
  52. } else {
  53. res, err := service.Logistics.Update(h.ctx, data)
  54. if err != nil {
  55. logrus.Errorf("[CreateLogisticsHandler] call Create err:%+v\n", err)
  56. util.HandlerPackErrorResp(h.resp, consts.ErrorInternal, "")
  57. log.Info("CreateProject fail,req:%+v", h.req)
  58. return
  59. }
  60. h.resp.Message = "成功修改物流信息"
  61. h.resp.Data = res
  62. }
  63. }
  64. func (h *CreateLogisticsHandler) checkParam() error {
  65. return nil
  66. }