query_rule_parser.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. package query_rule
  2. import (
  3. "encoding/json"
  4. "git.sxidc.com/go-framework/baize/framework/core/domain"
  5. "git.sxidc.com/go-framework/baize/framework/core/infrastructure"
  6. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database"
  7. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database/sql"
  8. "git.sxidc.com/go-framework/baize/framework/core/tag/rule"
  9. "git.sxidc.com/go-tools/utils/reflectutils"
  10. "git.sxidc.com/go-tools/utils/strutils"
  11. "github.com/pkg/errors"
  12. "reflect"
  13. )
  14. type Rule struct {
  15. FieldName string `json:"fieldName"`
  16. FieldType string `json:"fieldType"`
  17. ColumnName string `json:"columnName"`
  18. Operator string `json:"operator"`
  19. Value any `json:"value"`
  20. }
  21. func (r Rule) Check() error {
  22. if strutils.IsStringEmpty(r.FieldName) {
  23. return errors.New("字段名为空")
  24. }
  25. if !rule.IsSupportedType(r.FieldType) {
  26. return errors.New("字段类型不支持")
  27. }
  28. if strutils.IsStringEmpty(r.ColumnName) {
  29. return errors.New("列名为空")
  30. }
  31. if !IsSupportedOperator(r.Operator) {
  32. return errors.New("操作符不支持")
  33. }
  34. if r.Value == nil {
  35. return errors.New("没有传递值")
  36. }
  37. return nil
  38. }
  39. func Lint(ruleStr string) error {
  40. rules := make([]Rule, 0)
  41. err := json.Unmarshal([]byte(ruleStr), &rules)
  42. if err != nil {
  43. return err
  44. }
  45. for _, r := range rules {
  46. err := r.Check()
  47. if err != nil {
  48. return err
  49. }
  50. }
  51. return nil
  52. }
  53. func HasRule(dbSchema string, scope string, domainName string, i *infrastructure.Infrastructure) (bool, error) {
  54. dbExecutor := i.DBExecutor()
  55. return database.CheckExist(dbExecutor, &sql.CheckExistExecuteParams{
  56. TableName: domain.TableName(dbSchema, &ValueObject{}),
  57. Conditions: sql.NewConditions().Equal(ColumnScope, scope).Equal(ColumnDomainName, domainName),
  58. })
  59. }
  60. func GetRules(dbSchema string, scope string, domainName string, i *infrastructure.Infrastructure) ([]Rule, error) {
  61. dbExecutor := i.DBExecutor()
  62. result, err := database.QueryOne(dbExecutor, &sql.QueryOneExecuteParams{
  63. TableName: domain.TableName(dbSchema, &ValueObject{}),
  64. Conditions: sql.NewConditions().Equal(ColumnScope, scope).Equal(ColumnDomainName, domainName),
  65. })
  66. if err != nil {
  67. return nil, err
  68. }
  69. rules := make([]Rule, 0)
  70. err = json.Unmarshal([]byte(result.ColumnValueString(ColumnRule)), &rules)
  71. if err != nil {
  72. return nil, err
  73. }
  74. return rules, nil
  75. }
  76. func FormConditions(rules []Rule) (*sql.Conditions, error) {
  77. conditions := sql.NewConditions()
  78. for _, r := range rules {
  79. err := r.Check()
  80. if err != nil {
  81. return nil, err
  82. }
  83. switch r.Operator {
  84. case opEqual:
  85. conditions.Equal(r.ColumnName, r.Value)
  86. case opNotEqual:
  87. conditions.Not(r.ColumnName, r.Value)
  88. case opLessThan:
  89. conditions.LessThan(r.ColumnName, r.Value)
  90. case opLessThanOrEqual:
  91. conditions.LessThanAndEqual(r.ColumnName, r.Value)
  92. case opGreaterThan:
  93. conditions.GreaterThan(r.ColumnName, r.Value)
  94. case opGreaterThanOrEqual:
  95. conditions.GreaterThanAndEqual(r.ColumnName, r.Value)
  96. case opIn:
  97. if reflect.TypeOf(r.Value).Kind() != reflect.Slice {
  98. return nil, errors.New("使用\"包含在列表\"操作符必须使用列表")
  99. }
  100. conditions.In(r.FieldName, r.Value)
  101. case opNotIn:
  102. if reflect.TypeOf(r.Value).Kind() != reflect.Slice {
  103. return nil, errors.New("使用\"不包含在列表\"操作符必须使用列表")
  104. }
  105. conditions.NotIn(r.FieldName, r.Value)
  106. case opPrefix:
  107. strValue, err := reflectutils.ToString(r.Value)
  108. if err != nil {
  109. return nil, err
  110. }
  111. conditions.Like(r.FieldName, strValue+"%")
  112. case opSuffix:
  113. strValue, err := reflectutils.ToString(r.Value)
  114. if err != nil {
  115. return nil, err
  116. }
  117. conditions.Like(r.FieldName, "%"+strValue)
  118. case opContains:
  119. strValue, err := reflectutils.ToString(r.Value)
  120. if err != nil {
  121. return nil, err
  122. }
  123. conditions.Like(r.FieldName, "%"+strValue+"%")
  124. default:
  125. return nil, errors.Errorf("不支持的操作符%v", r.Operator)
  126. }
  127. }
  128. return conditions, nil
  129. }
  130. func GetRulesAndFormConditions(dbSchema string, scope string, domainName string, i *infrastructure.Infrastructure) (*sql.Conditions, error) {
  131. rules, err := GetRules(dbSchema, scope, domainName, i)
  132. if err != nil {
  133. return nil, err
  134. }
  135. conditions, err := FormConditions(rules)
  136. if err != nil {
  137. return nil, err
  138. }
  139. return conditions, nil
  140. }