post: retry 3 times before cancel

This commit is contained in:
Celogeek 2021-12-28 17:21:04 +01:00
parent f60d6f843f
commit 62ffdc83ef
Signed by: celogeek
GPG Key ID: E6B7BDCFC446233A

View File

@ -1,10 +1,9 @@
package piwigo package piwigo
import ( import (
"bytes"
"encoding/json" "encoding/json"
"fmt" "fmt"
"io" "io/ioutil"
"net/http" "net/http"
"net/url" "net/url"
"os" "os"
@ -36,6 +35,13 @@ func (p *Piwigo) Post(method string, form *url.Values, resp interface{}) error {
encodedForm = form.Encode() encodedForm = form.Encode()
} }
Result := PiwigoResult{
Result: resp,
}
var raw []byte
for i := 0; i < 3; i++ {
req, err := http.NewRequest("POST", Url, strings.NewReader(encodedForm)) req, err := http.NewRequest("POST", Url, strings.NewReader(encodedForm))
if err != nil { if err != nil {
return err return err
@ -48,40 +54,18 @@ func (p *Piwigo) Post(method string, form *url.Values, resp interface{}) error {
r, err := http.DefaultClient.Do(req) r, err := http.DefaultClient.Do(req)
if err != nil { if err != nil {
return err continue
} }
defer r.Body.Close() raw, err := ioutil.ReadAll(r.Body)
r.Body.Close()
Result := PiwigoResult{
Result: resp,
}
if os.Getenv("DEBUG") == "1" {
newBody := &bytes.Buffer{}
tee := io.TeeReader(r.Body, newBody)
var RawResult interface{}
err = json.NewDecoder(tee).Decode(&RawResult)
if err != nil { if err != nil {
return err continue
} }
DumpResponse(RawResult) err = json.Unmarshal(raw, &Result)
err = json.NewDecoder(newBody).Decode(&Result)
if err != nil { if err != nil {
return err continue
}
} else {
err = json.NewDecoder(r.Body).Decode(&Result)
if err != nil {
return err
}
}
if Result.Stat != "ok" {
return fmt.Errorf("[Error %d] %s", Result.Err, Result.ErrMessage)
} }
for _, c := range r.Cookies() { for _, c := range r.Cookies() {
@ -91,5 +75,26 @@ func (p *Piwigo) Post(method string, form *url.Values, resp interface{}) error {
} }
} }
break
}
if err != nil {
return err
}
if os.Getenv("DEBUG") == "1" {
var RawResult interface{}
err = json.Unmarshal(raw, RawResult)
if err != nil {
return err
}
DumpResponse(RawResult)
}
if Result.Stat != "ok" {
return fmt.Errorf("[Error %d] %s", Result.Err, Result.ErrMessage)
}
return nil return nil
} }