service.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. package one2one
  2. import (
  3. "encoding/json"
  4. "git.sxidc.com/go-framework/baize/convenient/binding"
  5. "git.sxidc.com/go-framework/baize/convenient/binding/request"
  6. "git.sxidc.com/go-framework/baize/framwork/api"
  7. "git.sxidc.com/go-framework/baize/framwork/domain"
  8. "git.sxidc.com/go-framework/baize/framwork/infrastructure"
  9. "git.sxidc.com/go-framework/baize/framwork/infrastructure/database"
  10. "git.sxidc.com/go-framework/baize/framwork/infrastructure/database/sql"
  11. "git.sxidc.com/go-tools/utils/strutils"
  12. "git.sxidc.com/service-supports/fserr"
  13. )
  14. func Update(fromTableName string, fromRelationFieldName string, fromRelationColumnName string, toTableName string, toDomainCNName string) binding.ServiceFunc[any] {
  15. return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
  16. object := objects[0]
  17. if object == nil {
  18. return nil, fserr.New("领域实体为空")
  19. }
  20. fromEntity, ok := object.(domain.Entity)
  21. if !ok {
  22. return nil, fserr.New("领域对象不是实体")
  23. }
  24. // 字段校验
  25. err := fromEntity.CheckFieldID(fromEntity.DomainCNName())
  26. if err != nil {
  27. return nil, err
  28. }
  29. if !domain.HasField(object, fromRelationFieldName) {
  30. return nil, fserr.New("关联字段" + fromRelationFieldName + "不存在")
  31. }
  32. // from存在性校验
  33. fromExist, err := database.CheckExist(i.DBExecutor(), &sql.CheckExistExecuteParams{
  34. TableName: fromTableName,
  35. Conditions: sql.NewConditions().Equal(domain.ColumnID, fromEntity.GetID()),
  36. })
  37. if err != nil {
  38. return nil, err
  39. }
  40. if !fromExist {
  41. return nil, fserr.New(fromEntity.DomainCNName() + "不存在")
  42. }
  43. toID, err := domain.Field[string](object, fromRelationFieldName)
  44. if err != nil {
  45. return nil, err
  46. }
  47. if strutils.IsStringNotEmpty(toID) {
  48. // to存在性校验
  49. toExist, err := database.CheckExist(i.DBExecutor(), &sql.CheckExistExecuteParams{
  50. TableName: toTableName,
  51. Conditions: sql.NewConditions().Equal(domain.ColumnID, toID),
  52. })
  53. if err != nil {
  54. return nil, err
  55. }
  56. if !toExist {
  57. return nil, fserr.New(fromEntity.DomainCNName() + "关联的" + toDomainCNName + "不存在")
  58. }
  59. }
  60. err = database.Update(i.DBExecutor(), &sql.UpdateExecuteParams{
  61. TableName: toTableName,
  62. TableRow: sql.NewTableRow().Add(fromRelationColumnName, toID),
  63. Conditions: sql.NewConditions().Equal(domain.ColumnID, fromEntity.GetID()),
  64. })
  65. if err != nil {
  66. return nil, err
  67. }
  68. return nil, nil
  69. }
  70. }
  71. func Query[TI any](tableName string) binding.ServiceFunc[TI] {
  72. return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (TI, error) {
  73. var info TI
  74. return info, nil
  75. }
  76. }
  77. func QueryWithOtherInfo[FI any, TI any](tableName string) binding.ServiceFunc[map[string]any] {
  78. return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (map[string]any, error) {
  79. info := new(struct {
  80. Self FI `json:"self"`
  81. With TI `json:"with"`
  82. })
  83. infoJson, err := json.Marshal(info)
  84. if err != nil {
  85. return nil, err
  86. }
  87. retMap := make(map[string]any)
  88. err = json.Unmarshal(infoJson, &retMap)
  89. if err != nil {
  90. return nil, err
  91. }
  92. return retMap, nil
  93. }
  94. }