query_rule_parser.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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 FormConditions(dbSchema string, scope string, domainName string, i *infrastructure.Infrastructure) (*sql.Conditions, error) {
  54. dbExecutor := i.DBExecutor()
  55. result, err := database.QueryOne(dbExecutor, &sql.QueryOneExecuteParams{
  56. TableName: domain.TableName(dbSchema, &ValueObject{}),
  57. Conditions: sql.NewConditions().Equal(ColumnScope, scope).Equal(ColumnDomainName, domainName),
  58. })
  59. if err != nil {
  60. return nil, err
  61. }
  62. rules := make([]Rule, 0)
  63. err = json.Unmarshal([]byte(result.ColumnValueString(ColumnRule)), &rules)
  64. if err != nil {
  65. return nil, err
  66. }
  67. conditions := sql.NewConditions()
  68. for _, r := range rules {
  69. err := r.Check()
  70. if err != nil {
  71. return nil, err
  72. }
  73. switch r.Operator {
  74. case opEqual:
  75. conditions.Equal(r.ColumnName, r.Value)
  76. case opNotEqual:
  77. conditions.Not(r.ColumnName, r.Value)
  78. case opLessThan:
  79. conditions.LessThan(r.ColumnName, r.Value)
  80. case opLessThanOrEqual:
  81. conditions.LessThanAndEqual(r.ColumnName, r.Value)
  82. case opGreaterThan:
  83. conditions.GreaterThan(r.ColumnName, r.Value)
  84. case opGreaterThanOrEqual:
  85. conditions.GreaterThanAndEqual(r.ColumnName, r.Value)
  86. case opIn:
  87. if reflect.TypeOf(r.Value).Kind() != reflect.Slice {
  88. return nil, errors.New("使用\"包含在列表\"操作符必须使用列表")
  89. }
  90. conditions.In(r.FieldName, r.Value)
  91. case opNotIn:
  92. if reflect.TypeOf(r.Value).Kind() != reflect.Slice {
  93. return nil, errors.New("使用\"不包含在列表\"操作符必须使用列表")
  94. }
  95. conditions.NotIn(r.FieldName, r.Value)
  96. case opPrefix:
  97. strValue, err := reflectutils.ToString(r.Value)
  98. if err != nil {
  99. return nil, err
  100. }
  101. conditions.Like(r.FieldName, strValue+"%")
  102. case opSuffix:
  103. strValue, err := reflectutils.ToString(r.Value)
  104. if err != nil {
  105. return nil, err
  106. }
  107. conditions.Like(r.FieldName, "%"+strValue)
  108. case opContains:
  109. strValue, err := reflectutils.ToString(r.Value)
  110. if err != nil {
  111. return nil, err
  112. }
  113. conditions.Like(r.FieldName, "%"+strValue+"%")
  114. default:
  115. return nil, errors.Errorf("不支持的操作符%v", r.Operator)
  116. }
  117. }
  118. return conditions, nil
  119. }