logistics_create.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package handler
  2. import (
  3. "fmt"
  4. "youngee_b_api/consts"
  5. "youngee_b_api/model/http_model"
  6. "youngee_b_api/service"
  7. "youngee_b_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. h.resp.Status = 20000
  53. } else {
  54. res, err := service.Logistics.Update(h.ctx, data)
  55. if err != nil {
  56. logrus.Errorf("[CreateLogisticsHandler] call Create err:%+v\n", err)
  57. util.HandlerPackErrorResp(h.resp, consts.ErrorInternal, "")
  58. log.Info("CreateProject fail,req:%+v", h.req)
  59. return
  60. }
  61. h.resp.Message = "成功修改物流信息"
  62. h.resp.Data = res
  63. h.resp.Status = 20000
  64. }
  65. }
  66. func (h *CreateLogisticsHandler) checkParam() error {
  67. return nil
  68. }