2019-08-02 02:48:38 +00:00
|
|
|
package common
|
|
|
|
|
|
|
|
import (
|
2019-08-06 03:24:38 +00:00
|
|
|
"bytes"
|
2019-08-02 02:48:38 +00:00
|
|
|
"crypto/tls"
|
2019-08-06 03:24:38 +00:00
|
|
|
"io/ioutil"
|
2019-08-02 02:48:38 +00:00
|
|
|
"net/http"
|
2019-08-09 16:39:40 +00:00
|
|
|
"net/url"
|
|
|
|
"strings"
|
2019-08-03 00:25:22 +00:00
|
|
|
|
2019-08-14 03:33:49 +00:00
|
|
|
"github.com/greenled/portainer-stack-utils/version"
|
|
|
|
|
2019-08-03 00:25:22 +00:00
|
|
|
"github.com/greenled/portainer-stack-utils/client"
|
2019-08-06 06:18:49 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
2019-08-02 02:48:38 +00:00
|
|
|
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
)
|
|
|
|
|
2019-08-03 00:25:22 +00:00
|
|
|
var cachedClient client.PortainerClient
|
2019-08-02 02:48:38 +00:00
|
|
|
|
2019-08-02 17:21:29 +00:00
|
|
|
// Get the cached client or a new one
|
2019-08-03 00:25:22 +00:00
|
|
|
func GetClient() (c client.PortainerClient, err error) {
|
2019-08-02 20:32:26 +00:00
|
|
|
if cachedClient == nil {
|
2019-08-02 22:20:18 +00:00
|
|
|
cachedClient, err = GetDefaultClient()
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return cachedClient, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the default client
|
2019-08-03 00:25:22 +00:00
|
|
|
func GetDefaultClient() (c client.PortainerClient, err error) {
|
2019-08-09 16:39:40 +00:00
|
|
|
config, err := GetDefaultClientConfig()
|
2019-08-06 03:23:16 +00:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-08-09 16:39:40 +00:00
|
|
|
c = client.NewClient(GetDefaultHttpClient(), config)
|
|
|
|
|
2019-08-06 03:23:16 +00:00
|
|
|
c.BeforeRequest(func(req *http.Request) (err error) {
|
2019-08-06 03:24:38 +00:00
|
|
|
var bodyString string
|
|
|
|
if req.Body != nil {
|
|
|
|
bodyBytes, readErr := ioutil.ReadAll(req.Body)
|
|
|
|
defer req.Body.Close()
|
|
|
|
if readErr != nil {
|
|
|
|
return readErr
|
|
|
|
}
|
|
|
|
bodyString = string(bodyBytes)
|
|
|
|
req.Body = ioutil.NopCloser(bytes.NewReader(bodyBytes))
|
|
|
|
}
|
|
|
|
|
2019-08-06 06:18:49 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"method": req.Method,
|
|
|
|
"url": req.URL.String(),
|
|
|
|
"body": string(bodyString),
|
|
|
|
}).Trace("Request to Portainer")
|
2019-08-06 03:24:38 +00:00
|
|
|
|
2019-08-06 03:23:16 +00:00
|
|
|
return
|
|
|
|
})
|
|
|
|
|
|
|
|
c.AfterResponse(func(resp *http.Response) (err error) {
|
2019-08-06 03:24:38 +00:00
|
|
|
var bodyString string
|
|
|
|
if resp.Body != nil {
|
|
|
|
bodyBytes, readErr := ioutil.ReadAll(resp.Body)
|
|
|
|
defer resp.Body.Close()
|
|
|
|
if readErr != nil {
|
|
|
|
return readErr
|
|
|
|
}
|
|
|
|
bodyString = string(bodyBytes)
|
|
|
|
resp.Body = ioutil.NopCloser(bytes.NewReader(bodyBytes))
|
|
|
|
}
|
|
|
|
|
2019-08-06 06:18:49 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"status": resp.Status,
|
|
|
|
"body": string(bodyString),
|
|
|
|
}).Trace("Response from Portainer")
|
2019-08-06 03:24:38 +00:00
|
|
|
|
2019-08-06 03:23:16 +00:00
|
|
|
return
|
|
|
|
})
|
|
|
|
|
|
|
|
return
|
2019-08-02 22:20:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get the default config for a client
|
2019-08-09 16:39:40 +00:00
|
|
|
func GetDefaultClientConfig() (config client.Config, err error) {
|
|
|
|
apiUrl, err := url.Parse(strings.TrimRight(viper.GetString("url"), "/") + "/api/")
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
config = client.Config{
|
|
|
|
Url: apiUrl,
|
2019-08-02 22:20:18 +00:00
|
|
|
User: viper.GetString("user"),
|
|
|
|
Password: viper.GetString("password"),
|
|
|
|
Token: viper.GetString("auth-token"),
|
2019-08-14 03:33:49 +00:00
|
|
|
UserAgent: version.BuildUseAgentString(),
|
2019-08-02 22:20:18 +00:00
|
|
|
DoNotUseToken: false,
|
|
|
|
}
|
2019-08-09 16:39:40 +00:00
|
|
|
|
|
|
|
return
|
2019-08-02 22:20:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get the default http client for a Portainer client
|
|
|
|
func GetDefaultHttpClient() *http.Client {
|
|
|
|
return &http.Client{
|
|
|
|
Timeout: viper.GetDuration("timeout"),
|
|
|
|
Transport: &http.Transport{
|
|
|
|
TLSClientConfig: &tls.Config{
|
|
|
|
InsecureSkipVerify: viper.GetBool("insecure"),
|
|
|
|
},
|
|
|
|
},
|
2019-08-02 02:48:38 +00:00
|
|
|
}
|
|
|
|
}
|