query_rule.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. package query_rule
  2. import (
  3. "git.sxidc.com/go-framework/baize/convenient/domain/query_rule/definition"
  4. "git.sxidc.com/go-framework/baize/convenient/domain/query_rule/rule"
  5. "git.sxidc.com/go-framework/baize/framework/binding"
  6. "git.sxidc.com/go-framework/baize/framework/core/api"
  7. "git.sxidc.com/go-framework/baize/framework/core/api/request"
  8. "git.sxidc.com/go-framework/baize/framework/core/api/response"
  9. "git.sxidc.com/go-framework/baize/framework/core/application"
  10. "git.sxidc.com/go-framework/baize/framework/core/domain"
  11. "git.sxidc.com/go-framework/baize/framework/core/domain/entity"
  12. "git.sxidc.com/go-framework/baize/framework/core/infrastructure"
  13. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database"
  14. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database/clause"
  15. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database/sql"
  16. "git.sxidc.com/go-tools/utils/strutils"
  17. "github.com/goccy/go-json"
  18. "github.com/pkg/errors"
  19. )
  20. // Simple Bind参数
  21. type Simple struct {
  22. // schema
  23. Schema string
  24. }
  25. func (simple *Simple) bind(binder *binding.Binder) {
  26. (&definition.Simple{Schema: simple.Schema}).Bind(binder)
  27. (&rule.Simple{Schema: simple.Schema}).Bind(binder)
  28. }
  29. func Bind(app *application.App, simple *Simple) {
  30. binder := binding.NewBinder(app.Api().ChooseRouter(api.RouterPrefix, ""), app.Infrastructure())
  31. simple.bind(binder)
  32. }
  33. type BaseAdvanceQueryParams struct {
  34. Rule string `json:"rule" assign:"-"`
  35. PageNo int `json:"pageNo" assign:"-"`
  36. PageSize int `json:"pageSize" assign:"-"`
  37. }
  38. type AddUseQueryRuleQueryRouteParams struct {
  39. DBSchema string
  40. DomainPath string
  41. Object domain.Object
  42. QueryMiddlewares []binding.Middleware
  43. }
  44. func AddUseQueryRuleQueryRoute[O any](binder *binding.Binder, addParams *AddUseQueryRuleQueryRouteParams) {
  45. binding.PostBind(binder, &binding.SimpleBindItem[response.InfosData[O]]{
  46. Path: addParams.DomainPath + "/advancedQuery",
  47. SendResponseFunc: response.SendInfosResponse[O],
  48. RequestParams: &BaseAdvanceQueryParams{},
  49. Objects: []domain.Object{addParams.Object},
  50. ServiceFunc: func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (response.InfosData[O], error) {
  51. errResponse := response.InfosData[O]{
  52. Infos: make([]O, 0),
  53. }
  54. if params == nil {
  55. return errResponse, errors.New("请求参数为空")
  56. }
  57. object := objects[0]
  58. if object == nil {
  59. return errResponse, errors.New("领域实体为空")
  60. }
  61. queryParams, ok := params.(*BaseAdvanceQueryParams)
  62. if !ok {
  63. return errResponse, errors.New("请求参数不是Query接口")
  64. }
  65. e, ok := objects[0].(entity.Entity)
  66. if !ok {
  67. return errResponse, errors.New("需要传递领域对象应该为实体")
  68. }
  69. var selectClause *clause.Select
  70. var countClause *clause.Select
  71. fromClause := clause.NewFrom([]clause.Clause{clause.TableName(domain.TableName(addParams.DBSchema, e))})
  72. limitClause := clause.NewLimit(queryParams.PageNo, queryParams.PageSize)
  73. if strutils.IsStringEmpty(queryParams.Rule) {
  74. selectClause = clause.NewSelect(nil, fromClause, limitClause)
  75. countClause = clause.NewSelect([]string{"COUNT(*) AS total"}, fromClause)
  76. } else {
  77. queryRule := new(rule.Rule)
  78. err := json.Unmarshal([]byte(queryParams.Rule), queryRule)
  79. if err != nil {
  80. return errResponse, err
  81. }
  82. conditionClause, err := rule.FormConditionClauseByRules(e.DomainCamelName(), *queryRule, nil)
  83. if err != nil {
  84. return errResponse, err
  85. }
  86. selectClause = clause.NewSelect(nil, fromClause, clause.NewWhere(conditionClause), limitClause)
  87. countClause = clause.NewSelect([]string{"COUNT(*) AS total"}, fromClause, clause.NewWhere(conditionClause))
  88. }
  89. selectClauseStr, err := selectClause.Clause()
  90. if err != nil {
  91. return errResponse, err
  92. }
  93. results, err := database.ExecuteRawSql(i.DBExecutor(), selectClauseStr, selectClause.Args()...)
  94. if err != nil {
  95. return errResponse, err
  96. }
  97. countClauseStr, err := countClause.Clause()
  98. if err != nil {
  99. return errResponse, err
  100. }
  101. countResults, err := database.ExecuteRawSql(i.DBExecutor(), countClauseStr, countClause.Args()...)
  102. if err != nil {
  103. return errResponse, err
  104. }
  105. infos := make([]O, 0)
  106. err = sql.ParseSqlResult(results, &infos)
  107. if err != nil {
  108. return errResponse, err
  109. }
  110. return response.InfosData[O]{
  111. Infos: infos,
  112. TotalCount: countResults[0].ColumnValueInt64("total"),
  113. PageNo: queryParams.PageNo,
  114. }, nil
  115. },
  116. }, addParams.QueryMiddlewares...)
  117. }