warehouse.go 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. package service
  2. import (
  3. "cold-delivery/app/admin/model"
  4. "cold-delivery/app/admin/service/dto"
  5. "cold-delivery/common/actions"
  6. cDto "cold-delivery/common/dto"
  7. "cold-delivery/common/global"
  8. "errors"
  9. "gogs.baozhida.cn/zoie/OAuth-core/service"
  10. "gorm.io/gorm"
  11. )
  12. type Warehouse struct {
  13. service.Service
  14. }
  15. func WarehouseIsBindUserScopes(isBind bool) func(db *gorm.DB) *gorm.DB {
  16. return func(db *gorm.DB) *gorm.DB {
  17. // 未发货
  18. if isBind {
  19. return db.Where("user_id > 0")
  20. }
  21. return db
  22. }
  23. }
  24. // GetPage 获取Warehouse列表
  25. func (e *Warehouse) GetPage(c *dto.WarehouseGetPageReq, list *[]model.Warehouse, count *int64, p *actions.DataPermission) error {
  26. var err error
  27. var data model.Warehouse
  28. err = e.Orm.Model(&data).
  29. Scopes(
  30. cDto.MakeCondition(c.GetNeedSearch()),
  31. cDto.Paginate(c.GetPageSize(), c.GetPageIndex()),
  32. actions.Permission(data.TableName(), p),
  33. WarehouseIsBindUserScopes(c.IsBind),
  34. ).
  35. Joins("User").
  36. Where("name like ? or User.nick_name like ?", "%"+c.Name+"%", "%"+c.Name+"%").
  37. Find(list).Limit(-1).Offset(-1).
  38. Count(count).Error
  39. if err != nil {
  40. e.Log.Errorf("db error: %s", err)
  41. return global.GetFailedErr
  42. }
  43. return nil
  44. }
  45. // Get 获取Warehouse对象
  46. func (e *Warehouse) Get(d *dto.WarehouseGetReq, warehouseModel *model.Warehouse, p *actions.DataPermission) error {
  47. err := e.Orm.
  48. Scopes(actions.Permission(warehouseModel.TableName(), p)).
  49. Preload("User").
  50. First(warehouseModel, d.GetId()).Error
  51. if err != nil {
  52. e.Log.Errorf("db error: %s", err)
  53. if errors.Is(err, gorm.ErrRecordNotFound) {
  54. return global.GetNotFoundOrNoPermissionErr
  55. }
  56. return global.GetFailedErr
  57. }
  58. return nil
  59. }
  60. // Insert 创建Warehouse对象
  61. func (e *Warehouse) Insert(c *dto.WarehouseInsertReq) error {
  62. var err error
  63. var data model.Warehouse
  64. tx := e.Orm.Begin()
  65. defer func() {
  66. if err != nil {
  67. tx.Rollback()
  68. } else {
  69. tx.Commit()
  70. }
  71. }()
  72. var i int64
  73. err = tx.Model(&data).Where("name = ? and dept_id = ?", c.Name, c.DeptId).Count(&i).Error
  74. if err != nil {
  75. e.Log.Errorf("db error: %s", err)
  76. return global.CreateFailedErr
  77. }
  78. if i > 0 {
  79. err = errors.New("仓库名已存在!")
  80. e.Log.Errorf("db error: %s", err)
  81. return err
  82. }
  83. var j int64
  84. err = tx.Model(&data).Where("user_id = ?", c.UserId).Count(&j).Error
  85. if err != nil {
  86. e.Log.Errorf("db error: %s", err)
  87. return global.CreateFailedErr
  88. }
  89. if j > 0 {
  90. err = errors.New("该用户已绑定其他仓库!")
  91. e.Log.Errorf("db error: %s", err)
  92. return err
  93. }
  94. var k int64
  95. err = tx.Model(&data).Where("sn = ?", c.Sn).Count(&k).Error
  96. if err != nil {
  97. e.Log.Errorf("db error: %s", err)
  98. return global.CreateFailedErr
  99. }
  100. if k > 0 {
  101. err = errors.New("该Sn已绑定其他仓库!")
  102. e.Log.Errorf("db error: %s", err)
  103. return err
  104. }
  105. // 添加仓库
  106. c.Generate(&data)
  107. data.HistorySn = []string{c.Sn}
  108. err = tx.Create(&data).Error
  109. if err != nil {
  110. e.Log.Errorf("db error: %s", err)
  111. return global.CreateFailedErr
  112. }
  113. c.Id = data.Id
  114. return nil
  115. }
  116. // Update 修改Warehouse对象
  117. func (e *Warehouse) Update(c *dto.WarehouseUpdateReq, p *actions.DataPermission) error {
  118. var err error
  119. tx := e.Orm.Begin()
  120. defer func() {
  121. if err != nil {
  122. tx.Rollback()
  123. } else {
  124. tx.Commit()
  125. }
  126. }()
  127. var warehouseModel = model.Warehouse{}
  128. // 查询仓库是否存在
  129. err = e.Orm.Scopes(actions.Permission(warehouseModel.TableName(), p)).
  130. First(&warehouseModel, c.GetId()).Error
  131. if err != nil {
  132. e.Log.Errorf("db error: %s", err)
  133. if errors.Is(err, gorm.ErrRecordNotFound) {
  134. return global.UpdateNotFoundOrNoPermissionErr
  135. }
  136. return global.UpdateFailedErr
  137. }
  138. if warehouseModel.Sn != c.Sn {
  139. var k int64
  140. var data = model.Warehouse{}
  141. err = tx.Model(&data).Where("sn = ?", c.Sn).Count(&k).Error
  142. if err != nil {
  143. e.Log.Errorf("db error: %s", err)
  144. return global.CreateFailedErr
  145. }
  146. if k > 0 {
  147. err = errors.New("该Sn已绑定其他仓库!")
  148. e.Log.Errorf("db error: %s", err)
  149. return err
  150. }
  151. warehouseModel.HistorySn = append(warehouseModel.HistorySn, c.Sn)
  152. }
  153. if warehouseModel.UserId != c.UserId {
  154. var k int64
  155. var data = model.Warehouse{}
  156. err = tx.Model(&data).Where("user_id = ?", c.UserId).Count(&k).Error
  157. if err != nil {
  158. e.Log.Errorf("db error: %s", err)
  159. return global.CreateFailedErr
  160. }
  161. if k > 0 {
  162. err = errors.New("该用户绑定其他仓库!")
  163. e.Log.Errorf("db error: %s", err)
  164. return err
  165. }
  166. }
  167. c.Generate(&warehouseModel)
  168. err = tx.Save(&warehouseModel).Error
  169. if err != nil {
  170. e.Log.Errorf("db error: %s", err)
  171. return global.UpdateFailedErr
  172. }
  173. c.Id = warehouseModel.Id
  174. return nil
  175. }
  176. // Remove 删除Warehouse
  177. func (e *Warehouse) Remove(c *dto.WarehouseDeleteReq, p *actions.DataPermission) error {
  178. var err error
  179. tx := e.Orm.Begin()
  180. defer func() {
  181. if err != nil {
  182. tx.Rollback()
  183. } else {
  184. tx.Commit()
  185. }
  186. }()
  187. var warehouseModel model.Warehouse
  188. // 查询仓库是否存在
  189. err = e.Orm.Scopes(actions.Permission(warehouseModel.TableName(), p)).
  190. First(&warehouseModel, c.GetId()).Error
  191. if err != nil {
  192. e.Log.Errorf("db error: %s", err)
  193. if errors.Is(err, gorm.ErrRecordNotFound) {
  194. return global.DeleteNotFoundOrNoPermissionErr
  195. }
  196. return global.DeleteFailedErr
  197. }
  198. db := tx.Delete(&warehouseModel)
  199. if err = db.Error; err != nil {
  200. e.Log.Errorf("db error: %s", err)
  201. return global.DeleteFailedErr
  202. }
  203. if db.RowsAffected == 0 {
  204. return global.DeleteNotFoundOrNoPermissionErr
  205. }
  206. return nil
  207. }
  208. // GetUserList 获取绑定车辆的用户
  209. func (e *Warehouse) GetUserList(c *dto.SysUserGetPageReq, p *actions.DataPermission, list *[]model.SysUserForBind, count *int64) error {
  210. var err error
  211. var userList []model.SysUserForBind
  212. var warehouseModel model.Warehouse
  213. var userModel model.SysUserForBind
  214. var userIds []int
  215. // 查询仓库是否存在
  216. err = e.Orm.Model(&warehouseModel).Select("user_id").Scopes(actions.Permission(warehouseModel.TableName(), p)).
  217. Find(&userIds).Error
  218. if err != nil {
  219. e.Log.Errorf("db error: %s", err)
  220. return global.GetFailedErr
  221. }
  222. err = e.Orm.
  223. Scopes(
  224. cDto.MakeCondition(c.GetNeedSearch()),
  225. cDto.Paginate(c.GetPageSize(), c.GetPageIndex()),
  226. actions.UserPermission(userModel.TableName(), p),
  227. ).
  228. Where("user_type = ? ", model.UserTypeSys).
  229. Find(&userList).Limit(-1).Offset(-1).
  230. Count(count).Error
  231. if err != nil {
  232. e.Log.Errorf("db error: %s", err)
  233. return global.GetFailedErr
  234. }
  235. userIdMap := make(map[int]bool)
  236. for _, id := range userIds {
  237. userIdMap[id] = true
  238. }
  239. for i := 0; i < len(userList); i++ {
  240. if _, ok := userIdMap[userList[i].Id]; ok {
  241. userList[i].IsBind = true
  242. }
  243. }
  244. *list = userList
  245. return nil
  246. }