| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281 | 
							- package feed
 
- import (
 
- 	"fmt"
 
- 	"kpt-tmr-group/http/middleware"
 
- 	"kpt-tmr-group/pkg/apierr"
 
- 	"kpt-tmr-group/pkg/ginutil"
 
- 	"kpt-tmr-group/pkg/valid"
 
- 	"kpt-tmr-group/pkg/xerr"
 
- 	operationPb "kpt-tmr-group/proto/go/backend/operation"
 
- 	"mime/multipart"
 
- 	"net/http"
 
- 	"path"
 
- 	"strconv"
 
- 	"time"
 
- 	"github.com/gin-gonic/gin"
 
- )
 
- func AddFeedFormula(c *gin.Context) {
 
- 	var req operationPb.AddFeedFormulaRequest
 
- 	if err := c.BindJSON(&req); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := valid.ValidateStruct(&req,
 
- 		valid.Field(&req.Name, valid.Required),
 
- 		valid.Field(&req.EncodeNumber, valid.Required, valid.Length(1, 30)),
 
- 		valid.Field(&req.Colour, valid.Required),
 
- 		valid.Field(&req.CattleCategoryId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.CattleCategoryName, valid.Required),
 
- 		valid.Field(&req.FormulaTypeId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.FormulaTypeName, valid.Required),
 
- 		valid.Field(&req.DataSourceId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.DataSourceName, valid.Required),
 
- 		valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),
 
- 		valid.Field(&req.IsModify, valid.Required, valid.Min(1), valid.Max(2)),
 
- 	); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := middleware.BackendOperation(c).OpsService.CreateFeedFormula(c, &req); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func EditFeedFormula(c *gin.Context) {
 
- 	var req operationPb.AddFeedFormulaRequest
 
- 	if err := c.BindJSON(&req); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := valid.ValidateStruct(&req,
 
- 		valid.Field(&req.Id, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.Name, valid.Required),
 
- 		valid.Field(&req.EncodeNumber, valid.Required, valid.Length(1, 30)),
 
- 		valid.Field(&req.Colour, valid.Required),
 
- 		valid.Field(&req.CattleCategoryId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.CattleCategoryName, valid.Required),
 
- 		valid.Field(&req.FormulaTypeId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.FormulaTypeName, valid.Required),
 
- 		valid.Field(&req.DataSourceId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.DataSourceName, valid.Required),
 
- 		valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),
 
- 		valid.Field(&req.IsModify, valid.Required, valid.Min(1), valid.Max(2)),
 
- 	); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := middleware.BackendOperation(c).OpsService.EditFeedFormula(c, &req); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func SearchFeedFormulaList(c *gin.Context) {
 
- 	req := &operationPb.SearchFeedFormulaRequest{}
 
- 	if err := ginutil.BindProto(c, req); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	req.Pagination = &operationPb.PaginationModel{
 
- 		Page:       int32(c.GetInt(middleware.Page)),
 
- 		PageSize:   int32(c.GetInt(middleware.PageSize)),
 
- 		PageOffset: int32(c.GetInt(middleware.PageOffset)),
 
- 	}
 
- 	res, err := middleware.BackendOperation(c).OpsService.SearchFeedFormulaList(c, req)
 
- 	if err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, res)
 
- }
 
- func DeleteFeedFormula(c *gin.Context) {
 
- 	feedFormulaIdStr := c.Param("feed_formula_id")
 
- 	feedFormulaId, _ := strconv.Atoi(feedFormulaIdStr)
 
- 	if err := valid.Validate(feedFormulaId, valid.Required, valid.Min(1)); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	if err := middleware.BackendOperation(c).OpsService.DeleteFeedFormula(c, int64(feedFormulaId)); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func IsShowModifyFeedFormula(c *gin.Context) {
 
- 	var req operationPb.IsShowModifyFeedFormula
 
- 	if err := c.BindJSON(&req); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := valid.ValidateStruct(&req,
 
- 		valid.Field(&req.FeedFormulaId, valid.Required, valid.Min(1)),
 
- 		valid.Field(&req.IsShow, valid.Required, valid.Min(1), valid.Max(2)),
 
- 	); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := middleware.BackendOperation(c).OpsService.IsShowFeedFormula(c, &req); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func ExcelImportFeedFormula(c *gin.Context) {
 
- 	file, err := func(c *gin.Context) (multipart.File, error) {
 
- 		if c.ContentType() != "multipart/form-data" {
 
- 			return nil, xerr.Custom("invalid Content-Type")
 
- 		}
 
- 		if c.Request.Body == nil || int(c.Request.ContentLength) <= 0 {
 
- 			return nil, xerr.Custom("invalid body")
 
- 		}
 
- 		file, fileHeader, err := c.Request.FormFile("file")
 
- 		if err != nil {
 
- 			return nil, xerr.WithStack(err)
 
- 		}
 
- 		fileSuffix := path.Ext(path.Base(fileHeader.Filename))
 
- 		if fileSuffix != ".xlsx" {
 
- 			return nil, xerr.Custom("invalid file suffix")
 
- 		}
 
- 		return file, nil
 
- 	}(c)
 
- 	if err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err = middleware.BackendOperation(c).OpsService.ExcelImportFeedFormula(c, file); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func ExcelExportFeedFormula(c *gin.Context) {
 
- 	req := &operationPb.SearchFeedFormulaRequest{}
 
- 	if err := c.BindJSON(req); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	req.Pagination = &operationPb.PaginationModel{
 
- 		Page:       int32(c.GetInt(middleware.Page)),
 
- 		PageSize:   int32(c.GetInt(middleware.PageSize)),
 
- 		PageOffset: int32(c.GetInt(middleware.PageOffset)),
 
- 	}
 
- 	buffer, err := middleware.BackendOperation(c).OpsService.ExcelExportFeedFormula(c, req)
 
- 	if err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	c.Header("Content-Type", "application/octet-stream")
 
- 	c.Header("Content-Disposition", "attachment; filename="+(fmt.Sprintf("饲料表 %s.xlsx", time.Now().Format("200601021504"))))
 
- 	if _, err = c.Writer.Write(buffer.Bytes()); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func ExcelTemplateFeedFormula(c *gin.Context) {
 
- 	buffer, err := middleware.BackendOperation(c).OpsService.ExcelTemplateFeedFormula(c)
 
- 	if err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	c.Header("Content-Type", "application/octet-stream")
 
- 	c.Header("Content-Disposition", "attachment; filename="+(fmt.Sprintf("饲料表 %s.xlsx", time.Now().Format("200601021504"))))
 
- 	if _, err = c.Writer.Write(buffer.Bytes()); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- func EncodeNumber(c *gin.Context) {
 
- 	ginutil.JSONResp(c, &operationPb.UniqueID{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.UniqueID_UniqueData{EncodeNumber: middleware.BackendOperation(c).OpsService.EncodeNumber(c)},
 
- 	})
 
- }
 
- // DistributeFeedFormula 饲料配方下发
 
- func DistributeFeedFormula(c *gin.Context) {
 
- 	req := &operationPb.DistributeFeedFormulaRequest{}
 
- 	if err := ginutil.BindProto(c, req); err != nil {
 
- 		apierr.AbortBadRequest(c, http.StatusBadRequest, err)
 
- 		return
 
- 	}
 
- 	if err := middleware.BackendOperation(c).OpsService.DistributeFeedFormula(c, req); err != nil {
 
- 		apierr.ClassifiedAbort(c, err)
 
- 		return
 
- 	}
 
- 	ginutil.JSONResp(c, &operationPb.CommonOK{
 
- 		Code: http.StatusOK,
 
- 		Msg:  "ok",
 
- 		Data: &operationPb.Success{Success: true},
 
- 	})
 
- }
 
- // Usage 配方使用情况
 
- func Usage(c *gin.Context) {
 
- }
 
 
  |