 237ef0de9b
			
		
	
	237ef0de9b
	
	
	
		
			
			This commit removes the following gogoproto extensions; - gogoproto.nullable - gogoproto.customename - gogoproto.unmarshaller_all - gogoproto.stringer_all - gogoproto.sizer_all - gogoproto.marshaler_all - gogoproto.goproto_unregonized_all - gogoproto.goproto_stringer_all - gogoproto.goproto_getters_all None of them are supported by Google's toolchain (see #6564). Signed-off-by: Kazuyoshi Kato <katokazu@amazon.com>
		
			
				
	
	
		
			211 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			211 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
|    Copyright The containerd Authors.
 | |
| 
 | |
|    Licensed under the Apache License, Version 2.0 (the "License");
 | |
|    you may not use this file except in compliance with the License.
 | |
|    You may obtain a copy of the License at
 | |
| 
 | |
|        http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
|    Unless required by applicable law or agreed to in writing, software
 | |
|    distributed under the License is distributed on an "AS IS" BASIS,
 | |
|    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|    See the License for the specific language governing permissions and
 | |
|    limitations under the License.
 | |
| */
 | |
| 
 | |
| package containerd
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"errors"
 | |
| 	"io"
 | |
| 
 | |
| 	containersapi "github.com/containerd/containerd/api/services/containers/v1"
 | |
| 	"github.com/containerd/containerd/containers"
 | |
| 	"github.com/containerd/containerd/errdefs"
 | |
| 	"github.com/containerd/containerd/protobuf"
 | |
| 	ptypes "github.com/containerd/containerd/protobuf/types"
 | |
| 	"github.com/containerd/typeurl"
 | |
| 	"google.golang.org/grpc/codes"
 | |
| 	"google.golang.org/grpc/status"
 | |
| )
 | |
| 
 | |
| type remoteContainers struct {
 | |
| 	client containersapi.ContainersClient
 | |
| }
 | |
| 
 | |
| var _ containers.Store = &remoteContainers{}
 | |
| 
 | |
| // NewRemoteContainerStore returns the container Store connected with the provided client
 | |
| func NewRemoteContainerStore(client containersapi.ContainersClient) containers.Store {
 | |
| 	return &remoteContainers{
 | |
| 		client: client,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *remoteContainers) Get(ctx context.Context, id string) (containers.Container, error) {
 | |
| 	resp, err := r.client.Get(ctx, &containersapi.GetContainerRequest{
 | |
| 		ID: id,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return containers.Container{}, errdefs.FromGRPC(err)
 | |
| 	}
 | |
| 
 | |
| 	return containerFromProto(resp.Container), nil
 | |
| }
 | |
| 
 | |
| func (r *remoteContainers) List(ctx context.Context, filters ...string) ([]containers.Container, error) {
 | |
| 	containers, err := r.stream(ctx, filters...)
 | |
| 	if err != nil {
 | |
| 		if err == errStreamNotAvailable {
 | |
| 			return r.list(ctx, filters...)
 | |
| 		}
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return containers, nil
 | |
| }
 | |
| 
 | |
| func (r *remoteContainers) list(ctx context.Context, filters ...string) ([]containers.Container, error) {
 | |
| 	resp, err := r.client.List(ctx, &containersapi.ListContainersRequest{
 | |
| 		Filters: filters,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return nil, errdefs.FromGRPC(err)
 | |
| 	}
 | |
| 	return containersFromProto(resp.Containers), nil
 | |
| }
 | |
| 
 | |
| var errStreamNotAvailable = errors.New("streaming api not available")
 | |
| 
 | |
| func (r *remoteContainers) stream(ctx context.Context, filters ...string) ([]containers.Container, error) {
 | |
| 	session, err := r.client.ListStream(ctx, &containersapi.ListContainersRequest{
 | |
| 		Filters: filters,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return nil, errdefs.FromGRPC(err)
 | |
| 	}
 | |
| 	var containers []containers.Container
 | |
| 	for {
 | |
| 		c, err := session.Recv()
 | |
| 		if err != nil {
 | |
| 			if err == io.EOF {
 | |
| 				return containers, nil
 | |
| 			}
 | |
| 			if s, ok := status.FromError(err); ok {
 | |
| 				if s.Code() == codes.Unimplemented {
 | |
| 					return nil, errStreamNotAvailable
 | |
| 				}
 | |
| 			}
 | |
| 			return nil, errdefs.FromGRPC(err)
 | |
| 		}
 | |
| 		select {
 | |
| 		case <-ctx.Done():
 | |
| 			return containers, ctx.Err()
 | |
| 		default:
 | |
| 			containers = append(containers, containerFromProto(c.Container))
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (r *remoteContainers) Create(ctx context.Context, container containers.Container) (containers.Container, error) {
 | |
| 	created, err := r.client.Create(ctx, &containersapi.CreateContainerRequest{
 | |
| 		Container: containerToProto(&container),
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return containers.Container{}, errdefs.FromGRPC(err)
 | |
| 	}
 | |
| 
 | |
| 	return containerFromProto(created.Container), nil
 | |
| 
 | |
| }
 | |
| 
 | |
| func (r *remoteContainers) Update(ctx context.Context, container containers.Container, fieldpaths ...string) (containers.Container, error) {
 | |
| 	var updateMask *ptypes.FieldMask
 | |
| 	if len(fieldpaths) > 0 {
 | |
| 		updateMask = &ptypes.FieldMask{
 | |
| 			Paths: fieldpaths,
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	updated, err := r.client.Update(ctx, &containersapi.UpdateContainerRequest{
 | |
| 		Container:  containerToProto(&container),
 | |
| 		UpdateMask: updateMask,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return containers.Container{}, errdefs.FromGRPC(err)
 | |
| 	}
 | |
| 
 | |
| 	return containerFromProto(updated.Container), nil
 | |
| 
 | |
| }
 | |
| 
 | |
| func (r *remoteContainers) Delete(ctx context.Context, id string) error {
 | |
| 	_, err := r.client.Delete(ctx, &containersapi.DeleteContainerRequest{
 | |
| 		ID: id,
 | |
| 	})
 | |
| 
 | |
| 	return errdefs.FromGRPC(err)
 | |
| 
 | |
| }
 | |
| 
 | |
| func containerToProto(container *containers.Container) *containersapi.Container {
 | |
| 	extensions := make(map[string]*ptypes.Any)
 | |
| 	for k, v := range container.Extensions {
 | |
| 		extensions[k] = protobuf.FromAny(v)
 | |
| 	}
 | |
| 	return &containersapi.Container{
 | |
| 		ID:     container.ID,
 | |
| 		Labels: container.Labels,
 | |
| 		Image:  container.Image,
 | |
| 		Runtime: &containersapi.Container_Runtime{
 | |
| 			Name:    container.Runtime.Name,
 | |
| 			Options: protobuf.FromAny(container.Runtime.Options),
 | |
| 		},
 | |
| 		Spec:        protobuf.FromAny(container.Spec),
 | |
| 		Snapshotter: container.Snapshotter,
 | |
| 		SnapshotKey: container.SnapshotKey,
 | |
| 		Extensions:  extensions,
 | |
| 		Sandbox:     container.SandboxID,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func containerFromProto(containerpb *containersapi.Container) containers.Container {
 | |
| 	var runtime containers.RuntimeInfo
 | |
| 	if containerpb.Runtime != nil {
 | |
| 		runtime = containers.RuntimeInfo{
 | |
| 			Name:    containerpb.Runtime.Name,
 | |
| 			Options: containerpb.Runtime.Options,
 | |
| 		}
 | |
| 	}
 | |
| 	extensions := make(map[string]typeurl.Any)
 | |
| 	for k, v := range containerpb.Extensions {
 | |
| 		v := v
 | |
| 		extensions[k] = v
 | |
| 	}
 | |
| 	return containers.Container{
 | |
| 		ID:          containerpb.ID,
 | |
| 		Labels:      containerpb.Labels,
 | |
| 		Image:       containerpb.Image,
 | |
| 		Runtime:     runtime,
 | |
| 		Spec:        containerpb.Spec,
 | |
| 		Snapshotter: containerpb.Snapshotter,
 | |
| 		SnapshotKey: containerpb.SnapshotKey,
 | |
| 		CreatedAt:   protobuf.FromTimestamp(containerpb.CreatedAt),
 | |
| 		UpdatedAt:   protobuf.FromTimestamp(containerpb.UpdatedAt),
 | |
| 		Extensions:  extensions,
 | |
| 		SandboxID:   containerpb.Sandbox,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func containersFromProto(containerspb []*containersapi.Container) []containers.Container {
 | |
| 	var containers []containers.Container
 | |
| 
 | |
| 	for _, container := range containerspb {
 | |
| 		container := container
 | |
| 		containers = append(containers, containerFromProto(container))
 | |
| 	}
 | |
| 
 | |
| 	return containers
 | |
| }
 |