Merge 'dev' into 'main'

This commit is contained in:
stSolo
2022-10-03 16:56:47 +03:00
parent 6271fa6d45
commit 5fd450382c
400 changed files with 14394 additions and 13407 deletions

129
client.go
View File

@@ -1,59 +1,70 @@
package decortsdk
import (
"context"
"errors"
"io"
"net/http"
"strings"
"github.com/google/go-querystring/query"
"github.com/rudecs/decort-sdk/config"
"github.com/rudecs/decort-sdk/internal/client"
)
type Client struct {
decortUrl string
client *http.Client
}
func New(cfg config.Config) *Client {
if cfg.Retries == 0 {
cfg.Retries = 5
}
return &Client{
decortUrl: cfg.DecortURL,
client: client.NewHttpClient(cfg),
}
}
func (dc *Client) DecortApiCall(ctx context.Context, method, url string, params interface{}) ([]byte, error) {
values, err := query.Values(params)
if err != nil {
return nil, err
}
body := strings.NewReader(values.Encode())
req, err := http.NewRequestWithContext(ctx, method, dc.decortUrl+"/restmachine"+url, body)
if err != nil {
return nil, err
}
resp, err := dc.client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
respBytes, err := io.ReadAll(resp.Body)
if err != nil {
return nil, err
}
if resp.StatusCode != 200 {
return nil, errors.New(string(respBytes))
}
return respBytes, nil
}
package decortsdk
import (
"context"
"errors"
"io"
"net/http"
"strings"
"github.com/rudecs/decort-sdk/pkg/cloudapi"
"github.com/rudecs/decort-sdk/pkg/cloudbroker"
"github.com/google/go-querystring/query"
"github.com/rudecs/decort-sdk/config"
"github.com/rudecs/decort-sdk/internal/client"
)
type Client struct {
decortURL string
client *http.Client
}
func New(cfg config.Config) *Client {
if cfg.Retries == 0 {
cfg.Retries = 5
}
return &Client{
decortURL: cfg.DecortURL,
client: client.NewHttpClient(cfg),
}
}
func (dc *Client) CloudApi() *cloudapi.CloudApi {
return cloudapi.New(dc)
}
func (dc *Client) CloudBroker() *cloudbroker.CloudBroker {
return cloudbroker.New(dc)
}
func (dc *Client) DecortApiCall(ctx context.Context, method, url string, params interface{}) ([]byte, error) {
values, err := query.Values(params)
if err != nil {
return nil, err
}
body := strings.NewReader(values.Encode())
req, err := http.NewRequestWithContext(ctx, method, dc.decortURL+"/restmachine"+url, body)
if err != nil {
return nil, err
}
resp, err := dc.client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
respBytes, err := io.ReadAll(resp.Body)
if err != nil {
return nil, err
}
if resp.StatusCode != 200 {
return nil, errors.New(string(respBytes))
}
return respBytes, nil
}