123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- package client
- import (
- "fmt"
- "git.sxidc.com/go-tools/api_binding/http_binding/response"
- "git.sxidc.com/service-supports/ds-sdk/client/request"
- "net/url"
- )
- const (
- executeRawSqlUrl = "/ds/api/v1/sql/rawSql/execute"
- parseSqlSpecUrl = "/ds/api/v1/sql/spec/parse"
- createSqlUrl = "/ds/api/v1/sql/create"
- deleteSqlUrl = "/ds/api/v1/sql/delete"
- getSqlsUrl = "/ds/api/v1/sql/query"
- executeSqlUrl = "/ds/api/v1/sql/execute"
- )
- func (c *Client) ExecuteRawSql(token string, baseUrl string,
- namespace string, dataSource string, sql string) ([]map[string]any, error) {
- fullUrl, err := url.JoinPath(baseUrl, executeRawSqlUrl)
- if err != nil {
- return nil, err
- }
- resp := new(struct {
- response.MsgResponse
- Results []map[string]any `json:"results"`
- })
- err = c.post(token, fullUrl, &request.ExecuteRawSqlRequest{
- Namespace: namespace,
- DataSource: dataSource,
- Sql: sql,
- }, resp)
- if err != nil {
- return nil, err
- }
- if !resp.Success {
- return nil, fmt.Errorf(resp.Msg)
- }
- return resp.Results, nil
- }
- func (c *Client) ParseSqlSpec(token string, baseUrl string, specJson string, executeParams map[string]any) (string, error) {
- fullUrl, err := url.JoinPath(baseUrl, parseSqlSpecUrl)
- if err != nil {
- return "", err
- }
- resp := new(struct {
- response.MsgResponse
- Parsed string `json:"parsed"`
- })
- err = c.post(token, fullUrl, &request.ParseSqlSpecRequest{
- Spec: specJson,
- ExecuteParams: executeParams,
- }, resp)
- if err != nil {
- return "", err
- }
- if !resp.Success {
- return "", fmt.Errorf(resp.Msg)
- }
- return resp.Parsed, nil
- }
- func (c *Client) CreateSql(token string, baseUrl string, namespace string, dataSource string, name string, spec string) error {
- fullUrl, err := url.JoinPath(baseUrl, createSqlUrl)
- if err != nil {
- return err
- }
- resp := new(response.MsgResponse)
- err = c.post(token, fullUrl, &request.CreateSqlRequest{
- Namespace: namespace,
- DataSource: dataSource,
- Name: name,
- Spec: spec,
- }, resp)
- if err != nil {
- return err
- }
- if !resp.Success {
- return fmt.Errorf(resp.Msg)
- }
- return nil
- }
- func (c *Client) DeleteSql(token string, baseUrl string, namespace string, dataSource string, name string) error {
- fullUrl, err := url.JoinPath(baseUrl, deleteSqlUrl)
- if err != nil {
- return err
- }
- resp := new(response.MsgResponse)
- err = c.post(token, fullUrl, &request.DeleteSqlRequest{
- Namespace: namespace,
- DataSource: dataSource,
- Name: name,
- }, resp)
- if err != nil {
- return err
- }
- if !resp.Success {
- return fmt.Errorf(resp.Msg)
- }
- return nil
- }
- func (c *Client) GetSqls(token string, baseUrl string, namespace string, dataSource string, name string) ([]SqlInfo, error) {
- fullUrl, err := url.JoinPath(baseUrl, getSqlsUrl)
- if err != nil {
- return nil, err
- }
- resp := new(response.InfosResponse[SqlInfo])
- err = c.get(token, fullUrl, map[string]string{
- "namespace": namespace,
- "dataSource": dataSource,
- "name": name,
- }, resp)
- if err != nil {
- return nil, err
- }
- if !resp.Success {
- return nil, fmt.Errorf(resp.Msg)
- }
- return resp.Infos, nil
- }
- func (c *Client) ExecuteSql(token string, baseUrl string,
- namespace string, dataSource string, name string, executeParams map[string]any) ([]map[string]any, error) {
- fullUrl, err := url.JoinPath(baseUrl, executeSqlUrl)
- if err != nil {
- return nil, err
- }
- resp := new(struct {
- response.MsgResponse
- Results []map[string]any `json:"results"`
- })
- err = c.post(token, fullUrl, &request.ExecuteSqlRequest{
- Namespace: namespace,
- DataSource: dataSource,
- Name: name,
- ExecuteParams: executeParams,
- }, resp)
- if err != nil {
- return nil, err
- }
- if !resp.Success {
- return nil, fmt.Errorf(resp.Msg)
- }
- return resp.Results, nil
- }
|