mirror of
https://github.com/zrepl/zrepl.git
synced 2024-11-22 16:34:32 +01:00
6c3f442f13
Also: - Defensive measures in control http server (1s timeouts) (prevent the leak, even if request body is not closed) - Add prometheus metrics to track control socket latencies (were used for debugging)
49 lines
981 B
Go
49 lines
981 B
Go
package client
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"encoding/json"
|
|
"github.com/pkg/errors"
|
|
"io"
|
|
"net"
|
|
"net/http"
|
|
)
|
|
|
|
func controlHttpClient(sockpath string) (client http.Client, err error) {
|
|
return http.Client{
|
|
Transport: &http.Transport{
|
|
DialContext: func(_ context.Context, _, _ string) (net.Conn, error) {
|
|
return net.Dial("unix", sockpath)
|
|
},
|
|
},
|
|
}, nil
|
|
}
|
|
|
|
func jsonRequestResponse(c http.Client, endpoint string, req interface{}, res interface{}) error {
|
|
var buf bytes.Buffer
|
|
encodeErr := json.NewEncoder(&buf).Encode(req)
|
|
if encodeErr != nil {
|
|
return encodeErr
|
|
}
|
|
|
|
resp, err := c.Post("http://unix"+endpoint, "application/json", &buf)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer resp.Body.Close()
|
|
|
|
if resp.StatusCode != http.StatusOK {
|
|
var msg bytes.Buffer
|
|
io.CopyN(&msg, resp.Body, 4096)
|
|
return errors.Errorf("%s", msg.String())
|
|
}
|
|
|
|
decodeError := json.NewDecoder(resp.Body).Decode(&res)
|
|
if decodeError != nil {
|
|
return decodeError
|
|
}
|
|
|
|
return nil
|
|
}
|