api.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. package sql_executor
  2. import (
  3. "git.sxidc.com/go-framework/baize/framework/binding"
  4. "git.sxidc.com/go-framework/baize/framework/binding/request"
  5. "git.sxidc.com/go-framework/baize/framework/binding/response"
  6. "git.sxidc.com/go-framework/baize/framework/core/api"
  7. "git.sxidc.com/go-framework/baize/framework/core/domain"
  8. "git.sxidc.com/go-framework/baize/framework/core/infrastructure"
  9. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database"
  10. "git.sxidc.com/go-framework/baize/framework/core/infrastructure/database/sql"
  11. "git.sxidc.com/go-tools/utils/strutils"
  12. )
  13. // Simple Bind参数
  14. type Simple struct {
  15. // schema
  16. Schema string
  17. }
  18. func (simple *Simple) bind(binder *binding.Binder) {
  19. sqlExecuteLogTableName := domain.TableName(simple.Schema, &SqlExecuteLog{})
  20. binding.PostBind(binder, &binding.SimpleBindItem[map[string]any]{
  21. Path: "/sql/execute",
  22. ResponseFunc: response.SendMapResponse,
  23. RequestParams: &ExecuteSqlJsonBody{},
  24. ServiceFunc: func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (map[string]any, error) {
  25. errResponse := map[string]any{
  26. "result": make([]sql.Result, 0),
  27. }
  28. dbExecutor := i.DBExecutor()
  29. jsonBody, err := request.ToConcrete[*ExecuteSqlJsonBody](params)
  30. if err != nil {
  31. return errResponse, err
  32. }
  33. var results []sql.Result
  34. err = database.Transaction(dbExecutor, func(tx database.Executor) error {
  35. innerResults, err := database.ExecuteRawSql(tx, jsonBody.Sql, nil)
  36. if err != nil {
  37. return err
  38. }
  39. sqlExecuteLog := &SqlExecuteLog{
  40. Sql: jsonBody.Sql,
  41. ExecutorName: jsonBody.ExecutorName,
  42. }
  43. err = sqlExecuteLog.ForCreate()
  44. if err != nil {
  45. return err
  46. }
  47. err = database.InsertEntity(tx, sqlExecuteLogTableName, sqlExecuteLog)
  48. if err != nil {
  49. return err
  50. }
  51. results = innerResults
  52. return nil
  53. })
  54. if err != nil {
  55. return errResponse, err
  56. }
  57. return map[string]any{
  58. "result": results,
  59. }, nil
  60. },
  61. })
  62. binding.GetBind(binder, &binding.SimpleBindItem[response.InfosData[SqlExecuteLogInfo]]{
  63. Path: "/sql/execute/log",
  64. ResponseFunc: response.SendInfosResponse[SqlExecuteLogInfo],
  65. RequestParams: &QuerySqlExecuteLogQueryParams{},
  66. ServiceFunc: func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (response.InfosData[SqlExecuteLogInfo], error) {
  67. errResponse := response.InfosData[SqlExecuteLogInfo]{
  68. Infos: make([]SqlExecuteLogInfo, 0),
  69. }
  70. dbExecutor := i.DBExecutor()
  71. queryParams, err := request.ToConcrete[*QuerySqlExecuteLogQueryParams](params)
  72. if err != nil {
  73. return errResponse, err
  74. }
  75. conditions := sql.NewConditions()
  76. if strutils.IsStringNotEmpty(queryParams.Sql) {
  77. conditions.Like(ColumnSql, "%"+queryParams.Sql+"%")
  78. }
  79. if strutils.IsStringNotEmpty(queryParams.ExecutorName) {
  80. conditions.Like(ColumnExecutorName, "%"+queryParams.ExecutorName+"%")
  81. }
  82. if strutils.IsStringNotEmpty(queryParams.StartExecuteTime) {
  83. conditions.GreaterThanAndEqual(ColumnExecutedTime, queryParams.StartExecuteTime)
  84. }
  85. if strutils.IsStringNotEmpty(queryParams.EndExecuteTime) {
  86. conditions.LessThanAndEqual(ColumnExecutedTime, queryParams.EndExecuteTime)
  87. }
  88. results, totalCount, err := database.Query(dbExecutor, &sql.QueryExecuteParams{
  89. TableName: sqlExecuteLogTableName,
  90. Conditions: conditions,
  91. PageNo: queryParams.PageNo,
  92. PageSize: queryParams.PageSize,
  93. })
  94. if err != nil {
  95. return errResponse, nil
  96. }
  97. infos := make([]SqlExecuteLogInfo, 0)
  98. err = sql.ParseSqlResult(results, &infos)
  99. if err != nil {
  100. return errResponse, nil
  101. }
  102. return response.InfosData[SqlExecuteLogInfo]{
  103. Infos: infos,
  104. TotalCount: totalCount,
  105. PageNo: queryParams.PageNo,
  106. }, nil
  107. },
  108. })
  109. }
  110. func BindSqlExecutor(binder *binding.Binder, simple *Simple) {
  111. simple.bind(binder)
  112. }