query_rule_parser.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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 FormConditions(dbSchema string, scope string, domainName string, i *infrastructure.Infrastructure) (*sql.Conditions, 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. conditions := sql.NewConditions()
  75. for _, r := range rules {
  76. err := r.Check()
  77. if err != nil {
  78. return nil, err
  79. }
  80. switch r.Operator {
  81. case opEqual:
  82. conditions.Equal(r.ColumnName, r.Value)
  83. case opNotEqual:
  84. conditions.Not(r.ColumnName, r.Value)
  85. case opLessThan:
  86. conditions.LessThan(r.ColumnName, r.Value)
  87. case opLessThanOrEqual:
  88. conditions.LessThanAndEqual(r.ColumnName, r.Value)
  89. case opGreaterThan:
  90. conditions.GreaterThan(r.ColumnName, r.Value)
  91. case opGreaterThanOrEqual:
  92. conditions.GreaterThanAndEqual(r.ColumnName, r.Value)
  93. case opIn:
  94. if reflect.TypeOf(r.Value).Kind() != reflect.Slice {
  95. return nil, errors.New("使用\"包含在列表\"操作符必须使用列表")
  96. }
  97. conditions.In(r.FieldName, r.Value)
  98. case opNotIn:
  99. if reflect.TypeOf(r.Value).Kind() != reflect.Slice {
  100. return nil, errors.New("使用\"不包含在列表\"操作符必须使用列表")
  101. }
  102. conditions.NotIn(r.FieldName, r.Value)
  103. case opPrefix:
  104. strValue, err := reflectutils.ToString(r.Value)
  105. if err != nil {
  106. return nil, err
  107. }
  108. conditions.Like(r.FieldName, strValue+"%")
  109. case opSuffix:
  110. strValue, err := reflectutils.ToString(r.Value)
  111. if err != nil {
  112. return nil, err
  113. }
  114. conditions.Like(r.FieldName, "%"+strValue)
  115. case opContains:
  116. strValue, err := reflectutils.ToString(r.Value)
  117. if err != nil {
  118. return nil, err
  119. }
  120. conditions.Like(r.FieldName, "%"+strValue+"%")
  121. default:
  122. return nil, errors.Errorf("不支持的操作符%v", r.Operator)
  123. }
  124. }
  125. return conditions, nil
  126. }