car.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. package service
  2. import (
  3. "cold-logistics/app/admin/model"
  4. "cold-logistics/app/admin/service/dto"
  5. "cold-logistics/common/actions"
  6. cDto "cold-logistics/common/dto"
  7. "cold-logistics/common/global"
  8. "errors"
  9. "gogs.baozhida.cn/zoie/OAuth-core/service"
  10. "gorm.io/gorm"
  11. )
  12. type Car struct {
  13. service.Service
  14. }
  15. // GetPage 获取Car列表
  16. func (e *Car) GetPage(c *dto.CarGetPageReq, list *[]model.Car, count *int64, p *actions.DataPermission) error {
  17. var err error
  18. var data model.Car
  19. err = e.Orm.Model(&data).
  20. Scopes(
  21. cDto.MakeCondition(c.GetNeedSearch()),
  22. cDto.Paginate(c.GetPageSize(), c.GetPageIndex()),
  23. actions.Permission(data.TableName(), p),
  24. ).
  25. Preload("User").
  26. Find(list).Limit(-1).Offset(-1).
  27. Count(count).Error
  28. if err != nil {
  29. e.Log.Errorf("db error: %s", err)
  30. return global.GetFailedErr
  31. }
  32. return nil
  33. }
  34. // Get 获取Car对象
  35. func (e *Car) Get(d *dto.CarGetReq, carModel *model.Car, p *actions.DataPermission) error {
  36. err := e.Orm.
  37. Scopes(actions.Permission(carModel.TableName(), p)).
  38. Preload("User").
  39. First(carModel, d.GetId()).Error
  40. if err != nil {
  41. e.Log.Errorf("db error: %s", err)
  42. if errors.Is(err, gorm.ErrRecordNotFound) {
  43. return global.GetNotFoundOrNoPermissionErr
  44. }
  45. return global.GetFailedErr
  46. }
  47. return nil
  48. }
  49. // Insert 创建Car对象
  50. func (e *Car) Insert(c *dto.CarInsertReq) error {
  51. var err error
  52. var data model.Car
  53. tx := e.Orm.Begin()
  54. defer func() {
  55. if err != nil {
  56. tx.Rollback()
  57. } else {
  58. tx.Commit()
  59. }
  60. }()
  61. var i int64
  62. err = tx.Model(&data).Where("car_no = ?", c.CarNo).Count(&i).Error
  63. if err != nil {
  64. e.Log.Errorf("db error: %s", err)
  65. return global.CreateFailedErr
  66. }
  67. if i > 0 {
  68. err = errors.New("车牌号已存在!")
  69. e.Log.Errorf("db error: %s", err)
  70. return err
  71. }
  72. var j int64
  73. err = tx.Model(&data).Where("user_id = ?", c.UserId).Count(&j).Error
  74. if err != nil {
  75. e.Log.Errorf("db error: %s", err)
  76. return global.CreateFailedErr
  77. }
  78. if j > 0 {
  79. err = errors.New("该用户已绑定其他车辆!")
  80. e.Log.Errorf("db error: %s", err)
  81. return err
  82. }
  83. var k int64
  84. err = tx.Model(&data).Where("sn = ?", c.Sn).Count(&k).Error
  85. if err != nil {
  86. e.Log.Errorf("db error: %s", err)
  87. return global.CreateFailedErr
  88. }
  89. if k > 0 {
  90. err = errors.New("该Sn已绑定其他车辆!")
  91. e.Log.Errorf("db error: %s", err)
  92. return err
  93. }
  94. // 添加仓库
  95. c.Generate(&data)
  96. err = tx.Create(&data).Error
  97. if err != nil {
  98. e.Log.Errorf("db error: %s", err)
  99. return global.CreateFailedErr
  100. }
  101. c.Id = data.Id
  102. return nil
  103. }
  104. // Update 修改Car对象
  105. func (e *Car) Update(c *dto.CarUpdateReq, p *actions.DataPermission) error {
  106. var err error
  107. tx := e.Orm.Begin()
  108. defer func() {
  109. if err != nil {
  110. tx.Rollback()
  111. } else {
  112. tx.Commit()
  113. }
  114. }()
  115. var carModel = model.Car{}
  116. // 查询仓库是否存在
  117. err = e.Orm.Scopes(actions.Permission(carModel.TableName(), p)).
  118. First(&carModel, c.GetId()).Error
  119. if err != nil {
  120. e.Log.Errorf("db error: %s", err)
  121. if errors.Is(err, gorm.ErrRecordNotFound) {
  122. return global.UpdateNotFoundOrNoPermissionErr
  123. }
  124. return global.UpdateFailedErr
  125. }
  126. if carModel.Sn != c.Sn {
  127. var k int64
  128. var data = model.Car{}
  129. err = tx.Model(&data).Where("sn = ?", c.Sn).Count(&k).Error
  130. if err != nil {
  131. e.Log.Errorf("db error: %s", err)
  132. return global.CreateFailedErr
  133. }
  134. if k > 0 {
  135. err = errors.New("该Sn已绑定其他车辆!")
  136. e.Log.Errorf("db error: %s", err)
  137. return err
  138. }
  139. }
  140. c.Generate(&carModel)
  141. err = tx.Save(&carModel).Error
  142. if err != nil {
  143. e.Log.Errorf("db error: %s", err)
  144. return global.UpdateFailedErr
  145. }
  146. c.Id = carModel.Id
  147. return nil
  148. }
  149. // Remove 删除Car
  150. func (e *Car) Remove(c *dto.CarDeleteReq, p *actions.DataPermission) error {
  151. var err error
  152. tx := e.Orm.Begin()
  153. defer func() {
  154. if err != nil {
  155. tx.Rollback()
  156. } else {
  157. tx.Commit()
  158. }
  159. }()
  160. var carModel model.Car
  161. // 查询仓库是否存在
  162. err = e.Orm.Scopes(actions.Permission(carModel.TableName(), p)).
  163. First(&carModel, c.GetId()).Error
  164. if err != nil {
  165. e.Log.Errorf("db error: %s", err)
  166. if errors.Is(err, gorm.ErrRecordNotFound) {
  167. return global.DeleteNotFoundOrNoPermissionErr
  168. }
  169. return global.DeleteFailedErr
  170. }
  171. db := tx.Delete(&carModel)
  172. if err = db.Error; err != nil {
  173. e.Log.Errorf("db error: %s", err)
  174. return global.DeleteFailedErr
  175. }
  176. if db.RowsAffected == 0 {
  177. return global.DeleteNotFoundOrNoPermissionErr
  178. }
  179. return nil
  180. }