api.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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. ExecutorID: jsonBody.ExecutorID,
  42. ExecutorName: jsonBody.ExecutorName,
  43. }
  44. err = sqlExecuteLog.ForCreate()
  45. if err != nil {
  46. return err
  47. }
  48. err = database.InsertEntity(tx, sqlExecuteLogTableName, sqlExecuteLog)
  49. if err != nil {
  50. return err
  51. }
  52. results = innerResults
  53. return nil
  54. })
  55. if err != nil {
  56. return errResponse, err
  57. }
  58. return map[string]any{
  59. "result": results,
  60. }, nil
  61. },
  62. })
  63. binding.GetBind(binder, &binding.SimpleBindItem[response.InfosData[SqlExecuteLogInfo]]{
  64. Path: "/sql/execute/log",
  65. ResponseFunc: response.SendInfosResponse[SqlExecuteLogInfo],
  66. RequestParams: &QuerySqlExecuteLogQueryParams{},
  67. ServiceFunc: func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (response.InfosData[SqlExecuteLogInfo], error) {
  68. errResponse := response.InfosData[SqlExecuteLogInfo]{
  69. Infos: make([]SqlExecuteLogInfo, 0),
  70. }
  71. dbExecutor := i.DBExecutor()
  72. queryParams, err := request.ToConcrete[*QuerySqlExecuteLogQueryParams](params)
  73. if err != nil {
  74. return errResponse, err
  75. }
  76. conditions := sql.NewConditions()
  77. if strutils.IsStringNotEmpty(queryParams.Sql) {
  78. conditions.Like(ColumnSql, "%"+queryParams.Sql+"%")
  79. }
  80. if strutils.IsStringNotEmpty(queryParams.ExecutorID) {
  81. conditions.Like(ColumnExecutorID, queryParams.ExecutorID)
  82. }
  83. if strutils.IsStringNotEmpty(queryParams.ExecutorName) {
  84. conditions.Like(ColumnExecutorName, "%"+queryParams.ExecutorName+"%")
  85. }
  86. if strutils.IsStringNotEmpty(queryParams.StartExecuteTime) {
  87. conditions.GreaterThanAndEqual(ColumnExecutedTime, queryParams.StartExecuteTime)
  88. }
  89. if strutils.IsStringNotEmpty(queryParams.EndExecuteTime) {
  90. conditions.LessThanAndEqual(ColumnExecutedTime, queryParams.EndExecuteTime)
  91. }
  92. results, totalCount, err := database.Query(dbExecutor, &sql.QueryExecuteParams{
  93. TableName: sqlExecuteLogTableName,
  94. Conditions: conditions,
  95. PageNo: queryParams.PageNo,
  96. PageSize: queryParams.PageSize,
  97. })
  98. if err != nil {
  99. return errResponse, nil
  100. }
  101. infos := make([]SqlExecuteLogInfo, 0)
  102. err = sql.ParseSqlResult(results, &infos)
  103. if err != nil {
  104. return errResponse, nil
  105. }
  106. return response.InfosData[SqlExecuteLogInfo]{
  107. Infos: infos,
  108. TotalCount: totalCount,
  109. PageNo: queryParams.PageNo,
  110. }, nil
  111. },
  112. })
  113. }
  114. func BindSqlExecutor(binder *binding.Binder, simple *Simple) {
  115. simple.bind(binder)
  116. }