upload_file.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. package backend
  2. import (
  3. "context"
  4. "fmt"
  5. "kpt-pasture/config"
  6. "kpt-pasture/model"
  7. "kpt-pasture/util"
  8. "mime/multipart"
  9. "os"
  10. "path/filepath"
  11. "strconv"
  12. "time"
  13. "gorm.io/gorm"
  14. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  15. "gitee.com/xuyiping_admin/pkg/xerr"
  16. )
  17. func (s *StoreEntry) Photos(ctx context.Context, files []*multipart.FileHeader) ([]string, error) {
  18. userModel, err := s.GetUserModel(ctx)
  19. if err != nil {
  20. return nil, err
  21. }
  22. workDir := fmt.Sprintf("%s", config.WorkDir)
  23. pathDir := fmt.Sprintf("/files/photos/%d/%s", userModel.AppPasture.Id, time.Now().Local().Format("20060102"))
  24. saveDir := filepath.Join(workDir, pathDir)
  25. if _, err = os.Stat(saveDir); os.IsNotExist(err) {
  26. if err = os.MkdirAll(saveDir, 0755); err != nil {
  27. return nil, xerr.Customf("创建目录失败: %s", err.Error())
  28. }
  29. }
  30. // 处理每个文件
  31. filePaths := make([]string, len(files))
  32. for i, file := range files {
  33. contentType := file.Header.Get("Content-Type")
  34. if contentType != "image/jpeg" && contentType != "image/png" && contentType != "image/gif" {
  35. return nil, xerr.Customf("图片格式错误: %s", file.Filename)
  36. }
  37. if file.Size > 1024*1024*5 {
  38. return nil, xerr.Customf("单个图片文件不能超过5MB")
  39. }
  40. ext := filepath.Ext(file.Filename)
  41. if ext == "" {
  42. switch contentType {
  43. case "image/jpeg":
  44. ext = ".jpg"
  45. case "image/png":
  46. ext = ".png"
  47. case "image/gif":
  48. ext = ".gif"
  49. default:
  50. ext = ".jpg" // 默认
  51. }
  52. }
  53. randomName := util.GenerateRandomNumberString(32)
  54. finalFilename := randomName + ext
  55. fPath := filepath.Join(saveDir, finalFilename)
  56. urlPath := filepath.Join(pathDir, finalFilename)
  57. if err = util.SaveUploadedFile(file, fPath); err != nil {
  58. return nil, xerr.Customf("保存文件失败: %s", err.Error())
  59. }
  60. filePaths[i] = urlPath
  61. }
  62. return filePaths, nil
  63. }
  64. func (s *StoreEntry) ImportExcel(ctx context.Context, data [][]string) error {
  65. // 获取当前用户信息
  66. userModel, err := s.GetUserModel(ctx)
  67. if err != nil {
  68. return err
  69. }
  70. penMap := model.PenMap
  71. if userModel.AppPasture.Id <= 0 {
  72. return xerr.Custom("无效的牧场ID")
  73. }
  74. // 处理Excel数据
  75. //headers := data[0]
  76. eventEnterList := make([]*pasturePb.EventEnterRequest, 0)
  77. for _, row := range data[1:] {
  78. if len(row) <= 0 {
  79. continue
  80. }
  81. ts := &pasturePb.EventEnterRequest{
  82. OperationId: 33,
  83. OperationName: "kpt_admin",
  84. MessengerId: 33,
  85. MessengerName: "kpt_admin",
  86. }
  87. for j, d := range row {
  88. switch j {
  89. case 0:
  90. continue
  91. case 1:
  92. continue
  93. case 2:
  94. ts.EarNumber = d
  95. case 3:
  96. if pn, ok := penMap[d]; ok {
  97. ts.PenId = pn
  98. ts.PenName = d
  99. }
  100. case 4:
  101. ts.Sex = pasturePb.Genders_Female
  102. if d == "公" {
  103. ts.Sex = pasturePb.Genders_Male
  104. }
  105. case 5:
  106. if d == "成母牛" {
  107. ts.CowType = pasturePb.CowType_Breeding_Calf
  108. } else if d == "犊牛" {
  109. ts.CowType = pasturePb.CowType_Lactating_Calf
  110. } else if d == "青年牛" {
  111. ts.CowType = pasturePb.CowType_Youth_Calf
  112. } else if d == "育成牛" {
  113. ts.CowType = pasturePb.CowType_Reserve_Calf
  114. }
  115. case 6:
  116. continue
  117. case 7:
  118. bat, _ := util.TimeParseLocal(model.LayoutTime2, d)
  119. if !bat.IsZero() {
  120. ts.BirthAt = int32(bat.Local().Unix())
  121. }
  122. case 8:
  123. lact, _ := strconv.Atoi(d)
  124. ts.Lact = int32(lact)
  125. case 9:
  126. eat, _ := util.TimeParseLocal(model.LayoutTime2, d)
  127. if !eat.IsZero() {
  128. ts.EnterAt = int32(eat.Local().Unix())
  129. }
  130. case 10:
  131. ts.FatherNumber = d
  132. case 11:
  133. ts.MotherNumber = d
  134. case 12:
  135. mat, _ := util.TimeParseLocal(model.LayoutTime2, d)
  136. if !mat.IsZero() {
  137. ts.MatingAt = int32(mat.Local().Unix())
  138. }
  139. case 13:
  140. continue
  141. case 14:
  142. continue
  143. case 15:
  144. mt, _ := strconv.Atoi(d)
  145. ts.MatingTimes = int32(mt)
  146. case 16:
  147. continue
  148. case 17:
  149. pat, _ := util.TimeParseLocal(model.LayoutTime2, d)
  150. if !pat.IsZero() {
  151. ts.PregnancyCheckAt = int32(pat.Local().Unix())
  152. }
  153. case 18:
  154. continue
  155. case 19:
  156. continue
  157. case 20:
  158. cat, _ := util.TimeParseLocal(model.LayoutTime2, d)
  159. if !cat.IsZero() {
  160. ts.CalvingAt = int32(cat.Local().Unix())
  161. }
  162. case 21:
  163. continue
  164. case 22:
  165. continue
  166. case 23:
  167. continue
  168. case 24:
  169. ts.CowKind = pasturePb.CowKind_AGSN
  170. }
  171. }
  172. eventEnterList = append(eventEnterList, ts)
  173. }
  174. if len(eventEnterList) <= 0 {
  175. return nil
  176. }
  177. pastureId := userModel.AppPasture.Id
  178. if pastureId != 4 {
  179. pastureId = 4
  180. }
  181. return s.ExecExcelData(ctx, pastureId, eventEnterList)
  182. }
  183. func (s *StoreEntry) ExecExcelData(ctx context.Context, pastureId int64, dataList []*pasturePb.EventEnterRequest) error {
  184. if len(dataList) <= 0 {
  185. return nil
  186. }
  187. return s.DB.Transaction(func(tx *gorm.DB) error {
  188. for _, data := range dataList {
  189. var count int64
  190. if err := tx.Model(new(model.Cow)).
  191. Where("pasture_id = ?", pastureId).
  192. Where("ear_number = ?", data.EarNumber).
  193. Count(&count).Error; err != nil {
  194. return err
  195. }
  196. if count > 0 {
  197. continue
  198. }
  199. if err := s.CreateEnter(ctx, data); err != nil {
  200. return err
  201. }
  202. }
  203. return nil
  204. })
  205. }