transaction_service.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. package entity_crud
  2. import (
  3. "git.sxidc.com/go-framework/baize/api"
  4. "git.sxidc.com/go-framework/baize/binding"
  5. "git.sxidc.com/go-framework/baize/binding/request"
  6. "git.sxidc.com/go-framework/baize/domain"
  7. "git.sxidc.com/go-framework/baize/infrastructure"
  8. "git.sxidc.com/go-framework/baize/infrastructure/database"
  9. "git.sxidc.com/go-framework/baize/infrastructure/database/sql"
  10. "git.sxidc.com/go-tools/utils/strutils"
  11. "git.sxidc.com/service-supports/fserr"
  12. )
  13. func CommonEntityCreateTx(tableName string, dbExecutor database.Executor, callbacks *Callbacks[string]) binding.ServiceFunc[string] {
  14. return func(c *api.Context, dto request.DTO, objects []domain.Object, i *infrastructure.Infrastructure) (string, error) {
  15. e, ok := objects[0].(domain.Entity)
  16. if !ok {
  17. return "", fserr.New("需要传递领域对象应该为实体")
  18. }
  19. err := e.GenerateID()
  20. if err != nil {
  21. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, "")
  22. }
  23. err = database.Transaction(dbExecutor, func(tx database.Executor) error {
  24. err = callbackBeforeDBOperate(callbacks, e, tx)
  25. if err != nil {
  26. return err
  27. }
  28. err = database.InsertEntity(tx, tableName, e)
  29. if err != nil {
  30. if database.IsErrorDBRecordHasExist(err) {
  31. err = fserr.New(e.DomainCNName() + "已存在")
  32. }
  33. return err
  34. }
  35. err = callbackAfterDBOperate(callbacks, e, tx)
  36. if err != nil {
  37. return err
  38. }
  39. return nil
  40. })
  41. if err != nil {
  42. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, "")
  43. }
  44. return callbackOnSuccessReturn(callbacks, e, dbExecutor, e.GetID())
  45. }
  46. }
  47. func CommonEntityDeleteTx(tableName string, dbExecutor database.Executor, callbacks *Callbacks[any]) binding.ServiceFunc[any] {
  48. return func(c *api.Context, dto request.DTO, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
  49. e, ok := objects[0].(domain.Entity)
  50. if !ok {
  51. return nil, fserr.New("需要传递领域对象应该为实体")
  52. }
  53. if strutils.IsStringEmpty(e.GetID()) {
  54. err := fserr.New("领域实体ID为空")
  55. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  56. }
  57. exist, err := database.CheckExist(dbExecutor, &sql.CheckExistExecuteParams{
  58. TableName: tableName,
  59. Conditions: sql.NewConditions().Equal(e.IDColumnName(), e.GetID()),
  60. })
  61. if err != nil {
  62. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  63. }
  64. if !exist {
  65. err := fserr.New(e.DomainCNName() + "不存在")
  66. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  67. }
  68. err = database.Transaction(dbExecutor, func(tx database.Executor) error {
  69. err = callbackBeforeDBOperate(callbacks, e, tx)
  70. if err != nil {
  71. return err
  72. }
  73. err = database.DeleteEntity(tx, tableName, e)
  74. if err != nil {
  75. return err
  76. }
  77. err = callbackAfterDBOperate(callbacks, e, tx)
  78. if err != nil {
  79. return err
  80. }
  81. return nil
  82. })
  83. if err != nil {
  84. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  85. }
  86. return callbackOnSuccessReturn(callbacks, e, dbExecutor, nil)
  87. }
  88. }
  89. func CommonEntityUpdateTx(tableName string, dbExecutor database.Executor, callbacks *Callbacks[any]) binding.ServiceFunc[any] {
  90. return func(c *api.Context, dto request.DTO, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
  91. e, ok := objects[0].(domain.Entity)
  92. if !ok {
  93. return nil, fserr.New("需要传递领域对象应该为实体")
  94. }
  95. if strutils.IsStringEmpty(e.GetID()) {
  96. err := fserr.New("领域实体ID为空")
  97. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  98. }
  99. exist, err := database.CheckExist(dbExecutor, &sql.CheckExistExecuteParams{
  100. TableName: tableName,
  101. Conditions: sql.NewConditions().Equal(e.IDColumnName(), e.GetID()),
  102. })
  103. if err != nil {
  104. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  105. }
  106. if !exist {
  107. err := fserr.New(e.DomainCNName() + "不存在")
  108. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  109. }
  110. err = database.Transaction(dbExecutor, func(tx database.Executor) error {
  111. err = callbackBeforeDBOperate(callbacks, e, tx)
  112. if err != nil {
  113. return err
  114. }
  115. err = database.UpdateEntity(tx, tableName, e)
  116. if err != nil {
  117. return err
  118. }
  119. err = callbackAfterDBOperate(callbacks, e, tx)
  120. if err != nil {
  121. return err
  122. }
  123. return nil
  124. })
  125. if err != nil {
  126. return callbackOnErrorReturn(callbacks, e, err, dbExecutor, nil)
  127. }
  128. return callbackOnSuccessReturn(callbacks, e, dbExecutor, nil)
  129. }
  130. }