|
@@ -4,9 +4,11 @@ import (
|
|
|
"bytes"
|
|
"bytes"
|
|
|
"fmt"
|
|
"fmt"
|
|
|
"io/ioutil"
|
|
"io/ioutil"
|
|
|
|
|
+ "net"
|
|
|
"net/http"
|
|
"net/http"
|
|
|
"net/url"
|
|
"net/url"
|
|
|
"path"
|
|
"path"
|
|
|
|
|
+ "time"
|
|
|
|
|
|
|
|
"github.com/grafana/grafana/pkg/util"
|
|
"github.com/grafana/grafana/pkg/util"
|
|
|
)
|
|
)
|
|
@@ -17,6 +19,18 @@ type WebdavUploader struct {
|
|
|
password string
|
|
password string
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+var netTransport = &http.Transport{
|
|
|
|
|
+ Dial: (&net.Dialer{
|
|
|
|
|
+ Timeout: 60 * time.Second,
|
|
|
|
|
+ }).Dial,
|
|
|
|
|
+ TLSHandshakeTimeout: 5 * time.Second,
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+var netClient = &http.Client{
|
|
|
|
|
+ Timeout: time.Second * 60,
|
|
|
|
|
+ Transport: netTransport,
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
func (u *WebdavUploader) Upload(pa string) (string, error) {
|
|
func (u *WebdavUploader) Upload(pa string) (string, error) {
|
|
|
url, _ := url.Parse(u.url)
|
|
url, _ := url.Parse(u.url)
|
|
|
url.Path = path.Join(url.Path, util.GetRandomString(20)+".png")
|
|
url.Path = path.Join(url.Path, util.GetRandomString(20)+".png")
|
|
@@ -28,7 +42,7 @@ func (u *WebdavUploader) Upload(pa string) (string, error) {
|
|
|
req.SetBasicAuth(u.username, u.password)
|
|
req.SetBasicAuth(u.username, u.password)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- res, err := http.DefaultClient.Do(req)
|
|
|
|
|
|
|
+ res, err := netClient.Do(req)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
return "", err
|
|
return "", err
|