Merge pull request #717 from 14rcole/oci-getcontainer
Allow oci memory store to match containers by id prefix or by name
This commit is contained in:
commit
da176cd379
7 changed files with 81 additions and 29 deletions
|
@ -1,7 +1,12 @@
|
||||||
package libkpod
|
package libkpod
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
cstorage "github.com/containers/storage"
|
cstorage "github.com/containers/storage"
|
||||||
|
"github.com/docker/docker/pkg/registrar"
|
||||||
|
"github.com/kubernetes-incubator/cri-o/libkpod/sandbox"
|
||||||
|
"github.com/kubernetes-incubator/cri-o/oci"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -75,3 +80,74 @@ func GetContainerRootFsSize(store cstorage.Store, containerID string) (int64, er
|
||||||
layerSize, err := store.DiffSize(layer.Parent, layer.ID)
|
layerSize, err := store.DiffSize(layer.Parent, layer.ID)
|
||||||
return size + layerSize, err
|
return size + layerSize, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetContainerFromRequest gets an oci container matching the specified full or partial id
|
||||||
|
func (c *ContainerServer) GetContainerFromRequest(cid string) (*oci.Container, error) {
|
||||||
|
if cid == "" {
|
||||||
|
return nil, fmt.Errorf("container ID should not be empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
containerID, err := c.ctrIDIndex.Get(cid)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("container with ID starting with %s not found: %v", cid, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ctr := c.GetContainer(containerID)
|
||||||
|
if ctr == nil {
|
||||||
|
return nil, fmt.Errorf("specified container not found: %s", containerID)
|
||||||
|
}
|
||||||
|
return ctr, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *ContainerServer) getSandboxFromRequest(pid string) (*sandbox.Sandbox, error) {
|
||||||
|
if pid == "" {
|
||||||
|
return nil, fmt.Errorf("pod ID should not be empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
podID, err := c.podIDIndex.Get(pid)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("pod with ID starting with %s not found: %v", pid, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
sb := c.GetSandbox(podID)
|
||||||
|
if sb == nil {
|
||||||
|
return nil, fmt.Errorf("specified pod not found: %s", podID)
|
||||||
|
}
|
||||||
|
return sb, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// LookupContainer returns the container with the given name or full or partial id
|
||||||
|
func (c *ContainerServer) LookupContainer(idOrName string) (*oci.Container, error) {
|
||||||
|
if idOrName == "" {
|
||||||
|
return nil, fmt.Errorf("container ID or name should not be empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrID, err := c.ctrNameIndex.Get(idOrName)
|
||||||
|
if err != nil {
|
||||||
|
if err == registrar.ErrNameNotReserved {
|
||||||
|
ctrID = idOrName
|
||||||
|
} else {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.GetContainerFromRequest(ctrID)
|
||||||
|
}
|
||||||
|
|
||||||
|
// LookupSandbox returns the pod sandbox with the given name or full or partial id
|
||||||
|
func (c *ContainerServer) LookupSandbox(idOrName string) (*sandbox.Sandbox, error) {
|
||||||
|
if idOrName == "" {
|
||||||
|
return nil, fmt.Errorf("container ID or name should not be empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
podID, err := c.podNameIndex.Get(idOrName)
|
||||||
|
if err != nil {
|
||||||
|
if err == registrar.ErrNameNotReserved {
|
||||||
|
podID = idOrName
|
||||||
|
} else {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.getSandboxFromRequest(podID)
|
||||||
|
}
|
||||||
|
|
|
@ -1,24 +0,0 @@
|
||||||
package server
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
|
|
||||||
"github.com/kubernetes-incubator/cri-o/oci"
|
|
||||||
)
|
|
||||||
|
|
||||||
func (s *Server) getContainerFromRequest(cid string) (*oci.Container, error) {
|
|
||||||
if cid == "" {
|
|
||||||
return nil, fmt.Errorf("container ID should not be empty")
|
|
||||||
}
|
|
||||||
|
|
||||||
containerID, err := s.CtrIDIndex().Get(cid)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("container with ID starting with %s not found: %v", cid, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
c := s.ContainerServer.GetContainer(containerID)
|
|
||||||
if c == nil {
|
|
||||||
return nil, fmt.Errorf("specified container not found: %s", containerID)
|
|
||||||
}
|
|
||||||
return c, nil
|
|
||||||
}
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
// ExecSync runs a command in a container synchronously.
|
// ExecSync runs a command in a container synchronously.
|
||||||
func (s *Server) ExecSync(ctx context.Context, req *pb.ExecSyncRequest) (*pb.ExecSyncResponse, error) {
|
func (s *Server) ExecSync(ctx context.Context, req *pb.ExecSyncRequest) (*pb.ExecSyncResponse, error) {
|
||||||
logrus.Debugf("ExecSyncRequest %+v", req)
|
logrus.Debugf("ExecSyncRequest %+v", req)
|
||||||
c, err := s.getContainerFromRequest(req.ContainerId)
|
c, err := s.GetContainerFromRequest(req.ContainerId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ import (
|
||||||
// should be force removed.
|
// should be force removed.
|
||||||
func (s *Server) RemoveContainer(ctx context.Context, req *pb.RemoveContainerRequest) (*pb.RemoveContainerResponse, error) {
|
func (s *Server) RemoveContainer(ctx context.Context, req *pb.RemoveContainerRequest) (*pb.RemoveContainerResponse, error) {
|
||||||
logrus.Debugf("RemoveContainerRequest %+v", req)
|
logrus.Debugf("RemoveContainerRequest %+v", req)
|
||||||
c, err := s.getContainerFromRequest(req.ContainerId)
|
c, err := s.GetContainerFromRequest(req.ContainerId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
// StartContainer starts the container.
|
// StartContainer starts the container.
|
||||||
func (s *Server) StartContainer(ctx context.Context, req *pb.StartContainerRequest) (*pb.StartContainerResponse, error) {
|
func (s *Server) StartContainer(ctx context.Context, req *pb.StartContainerRequest) (*pb.StartContainerResponse, error) {
|
||||||
logrus.Debugf("StartContainerRequest %+v", req)
|
logrus.Debugf("StartContainerRequest %+v", req)
|
||||||
c, err := s.getContainerFromRequest(req.ContainerId)
|
c, err := s.GetContainerFromRequest(req.ContainerId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ const (
|
||||||
// ContainerStatus returns status of the container.
|
// ContainerStatus returns status of the container.
|
||||||
func (s *Server) ContainerStatus(ctx context.Context, req *pb.ContainerStatusRequest) (*pb.ContainerStatusResponse, error) {
|
func (s *Server) ContainerStatus(ctx context.Context, req *pb.ContainerStatusRequest) (*pb.ContainerStatusResponse, error) {
|
||||||
logrus.Debugf("ContainerStatusRequest %+v", req)
|
logrus.Debugf("ContainerStatusRequest %+v", req)
|
||||||
c, err := s.getContainerFromRequest(req.ContainerId)
|
c, err := s.GetContainerFromRequest(req.ContainerId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
// StopContainer stops a running container with a grace period (i.e., timeout).
|
// StopContainer stops a running container with a grace period (i.e., timeout).
|
||||||
func (s *Server) StopContainer(ctx context.Context, req *pb.StopContainerRequest) (*pb.StopContainerResponse, error) {
|
func (s *Server) StopContainer(ctx context.Context, req *pb.StopContainerRequest) (*pb.StopContainerResponse, error) {
|
||||||
logrus.Debugf("StopContainerRequest %+v", req)
|
logrus.Debugf("StopContainerRequest %+v", req)
|
||||||
c, err := s.getContainerFromRequest(req.ContainerId)
|
c, err := s.GetContainerFromRequest(req.ContainerId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue