sql.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. package client
  2. import (
  3. "fmt"
  4. "git.sxidc.com/go-tools/api_binding/http_binding/response"
  5. "git.sxidc.com/service-supports/ds-sdk/client/request"
  6. "net/url"
  7. )
  8. const (
  9. executeRawSqlUrl = "/ds/api/v1/sql/rawSql/execute"
  10. parseSqlSpecUrl = "/ds/api/v1/sql/spec/parse"
  11. createSqlUrl = "/ds/api/v1/sql/create"
  12. deleteSqlUrl = "/ds/api/v1/sql/delete"
  13. getSqlsUrl = "/ds/api/v1/sql/query"
  14. executeSqlUrl = "/ds/api/v1/sql/execute"
  15. )
  16. func (c *Client) ExecuteRawSql(token string, baseUrl string,
  17. namespace string, dataSource string, sql string) ([]map[string]any, error) {
  18. fullUrl, err := url.JoinPath(baseUrl, executeRawSqlUrl)
  19. if err != nil {
  20. return nil, err
  21. }
  22. resp := new(struct {
  23. response.MsgResponse
  24. Results []map[string]any `json:"results"`
  25. })
  26. err = c.post(token, fullUrl, &request.ExecuteRawSqlRequest{
  27. Namespace: namespace,
  28. DataSource: dataSource,
  29. Sql: sql,
  30. }, resp)
  31. if err != nil {
  32. return nil, err
  33. }
  34. if !resp.Success {
  35. return nil, fmt.Errorf(resp.Msg)
  36. }
  37. return resp.Results, nil
  38. }
  39. func (c *Client) ParseSqlSpec(token string, baseUrl string, specJson string, executeParams map[string]any) (string, error) {
  40. fullUrl, err := url.JoinPath(baseUrl, parseSqlSpecUrl)
  41. if err != nil {
  42. return "", err
  43. }
  44. resp := new(struct {
  45. response.MsgResponse
  46. Parsed string `json:"parsed"`
  47. })
  48. err = c.post(token, fullUrl, &request.ParseSqlSpecRequest{
  49. Spec: specJson,
  50. ExecuteParams: executeParams,
  51. }, resp)
  52. if err != nil {
  53. return "", err
  54. }
  55. if !resp.Success {
  56. return "", fmt.Errorf(resp.Msg)
  57. }
  58. return resp.Parsed, nil
  59. }
  60. func (c *Client) CreateSql(token string, baseUrl string, namespace string, dataSource string, name string, spec string) error {
  61. fullUrl, err := url.JoinPath(baseUrl, createSqlUrl)
  62. if err != nil {
  63. return err
  64. }
  65. resp := new(response.MsgResponse)
  66. err = c.post(token, fullUrl, &request.CreateSqlRequest{
  67. Namespace: namespace,
  68. DataSource: dataSource,
  69. Name: name,
  70. Spec: spec,
  71. }, resp)
  72. if err != nil {
  73. return err
  74. }
  75. if !resp.Success {
  76. return fmt.Errorf(resp.Msg)
  77. }
  78. return nil
  79. }
  80. func (c *Client) DeleteSql(token string, baseUrl string, namespace string, dataSource string, name string) error {
  81. fullUrl, err := url.JoinPath(baseUrl, deleteSqlUrl)
  82. if err != nil {
  83. return err
  84. }
  85. resp := new(response.MsgResponse)
  86. err = c.post(token, fullUrl, &request.DeleteSqlRequest{
  87. Namespace: namespace,
  88. DataSource: dataSource,
  89. Name: name,
  90. }, resp)
  91. if err != nil {
  92. return err
  93. }
  94. if !resp.Success {
  95. return fmt.Errorf(resp.Msg)
  96. }
  97. return nil
  98. }
  99. func (c *Client) GetSqls(token string, baseUrl string, namespace string, dataSource string, name string) ([]SqlInfo, error) {
  100. fullUrl, err := url.JoinPath(baseUrl, getSqlsUrl)
  101. if err != nil {
  102. return nil, err
  103. }
  104. resp := new(response.InfosResponse[SqlInfo])
  105. err = c.get(token, fullUrl, map[string]string{
  106. "namespace": namespace,
  107. "dataSource": dataSource,
  108. "name": name,
  109. }, resp)
  110. if err != nil {
  111. return nil, err
  112. }
  113. if !resp.Success {
  114. return nil, fmt.Errorf(resp.Msg)
  115. }
  116. return resp.Infos, nil
  117. }
  118. func (c *Client) ExecuteSql(token string, baseUrl string,
  119. namespace string, dataSource string, name string, executeParams map[string]any) ([]map[string]any, error) {
  120. fullUrl, err := url.JoinPath(baseUrl, executeSqlUrl)
  121. if err != nil {
  122. return nil, err
  123. }
  124. resp := new(struct {
  125. response.MsgResponse
  126. Results []map[string]any `json:"results"`
  127. })
  128. err = c.post(token, fullUrl, &request.ExecuteSqlRequest{
  129. Namespace: namespace,
  130. DataSource: dataSource,
  131. Name: name,
  132. ExecuteParams: executeParams,
  133. }, resp)
  134. if err != nil {
  135. return nil, err
  136. }
  137. if !resp.Success {
  138. return nil, fmt.Errorf(resp.Msg)
  139. }
  140. return resp.Results, nil
  141. }