diff options
Diffstat (limited to 'client/client.go')
-rw-r--r-- | client/client.go | 103 |
1 files changed, 0 insertions, 103 deletions
diff --git a/client/client.go b/client/client.go deleted file mode 100644 index ad717b970..000000000 --- a/client/client.go +++ /dev/null @@ -1,103 +0,0 @@ -package client - -import ( - "encoding/json" - "fmt" - "net" - "net/http" - "syscall" - "time" - - "github.com/kubernetes-incubator/cri-o/types" -) - -const ( - maxUnixSocketPathSize = len(syscall.RawSockaddrUnix{}.Path) -) - -// CrioClient is an interface to get information from crio daemon endpoint. -type CrioClient interface { - DaemonInfo() (types.CrioInfo, error) - ContainerInfo(string) (*types.ContainerInfo, error) -} - -type crioClientImpl struct { - client *http.Client - crioSocketPath string -} - -func configureUnixTransport(tr *http.Transport, proto, addr string) error { - if len(addr) > maxUnixSocketPathSize { - return fmt.Errorf("Unix socket path %q is too long", addr) - } - // No need for compression in local communications. - tr.DisableCompression = true - tr.Dial = func(_, _ string) (net.Conn, error) { - return net.DialTimeout(proto, addr, 32*time.Second) - } - return nil -} - -// New returns a crio client -func New(crioSocketPath string) (CrioClient, error) { - tr := new(http.Transport) - configureUnixTransport(tr, "unix", crioSocketPath) - c := &http.Client{ - Transport: tr, - } - return &crioClientImpl{ - client: c, - crioSocketPath: crioSocketPath, - }, nil -} - -func (c *crioClientImpl) getRequest(path string) (*http.Request, error) { - req, err := http.NewRequest("GET", path, nil) - if err != nil { - return nil, err - } - // For local communications over a unix socket, it doesn't matter what - // the host is. We just need a valid and meaningful host name. - req.Host = "crio" - req.URL.Host = c.crioSocketPath - req.URL.Scheme = "http" - return req, nil -} - -// DaemonInfo return cri-o daemon info from the cri-o -// info endpoint. -func (c *crioClientImpl) DaemonInfo() (types.CrioInfo, error) { - info := types.CrioInfo{} - req, err := c.getRequest("/info") - if err != nil { - return info, err - } - resp, err := c.client.Do(req) - if err != nil { - return info, err - } - defer resp.Body.Close() - if err := json.NewDecoder(resp.Body).Decode(&info); err != nil { - return info, err - } - return info, nil -} - -// ContainerInfo returns container info by querying -// the cri-o container endpoint. -func (c *crioClientImpl) ContainerInfo(id string) (*types.ContainerInfo, error) { - req, err := c.getRequest("/containers/" + id) - if err != nil { - return nil, err - } - resp, err := c.client.Do(req) - if err != nil { - return nil, err - } - defer resp.Body.Close() - cInfo := types.ContainerInfo{} - if err := json.NewDecoder(resp.Body).Decode(&cInfo); err != nil { - return nil, err - } - return &cInfo, nil -} |