109 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// +build linux
 | 
						|
 | 
						|
package linux
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"context"
 | 
						|
	"io"
 | 
						|
	"os"
 | 
						|
	"path/filepath"
 | 
						|
 | 
						|
	"github.com/containerd/containerd/events"
 | 
						|
	"github.com/containerd/containerd/linux/runcopts"
 | 
						|
	client "github.com/containerd/containerd/linux/shim"
 | 
						|
	"github.com/containerd/containerd/runtime"
 | 
						|
	"github.com/containerd/containerd/typeurl"
 | 
						|
)
 | 
						|
 | 
						|
func loadBundle(path, namespace string, events *events.Exchange) *bundle {
 | 
						|
	return &bundle{
 | 
						|
		path:      path,
 | 
						|
		namespace: namespace,
 | 
						|
		events:    events,
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// newBundle creates a new bundle on disk at the provided path for the given id
 | 
						|
func newBundle(path, namespace, id string, spec []byte, events *events.Exchange) (b *bundle, err error) {
 | 
						|
	if err := os.MkdirAll(path, 0711); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	path = filepath.Join(path, id)
 | 
						|
	defer func() {
 | 
						|
		if err != nil {
 | 
						|
			os.RemoveAll(path)
 | 
						|
		}
 | 
						|
	}()
 | 
						|
	if err := os.Mkdir(path, 0711); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	if err := os.Mkdir(filepath.Join(path, "rootfs"), 0711); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	f, err := os.Create(filepath.Join(path, configFilename))
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	defer f.Close()
 | 
						|
	_, err = io.Copy(f, bytes.NewReader(spec))
 | 
						|
	return &bundle{
 | 
						|
		id:        id,
 | 
						|
		path:      path,
 | 
						|
		namespace: namespace,
 | 
						|
		events:    events,
 | 
						|
	}, err
 | 
						|
}
 | 
						|
 | 
						|
type bundle struct {
 | 
						|
	id        string
 | 
						|
	path      string
 | 
						|
	namespace string
 | 
						|
	events    *events.Exchange
 | 
						|
}
 | 
						|
 | 
						|
// NewShim connects to the shim managing the bundle and tasks
 | 
						|
func (b *bundle) NewShim(ctx context.Context, binary, grpcAddress string, remote, debug bool, createOpts runtime.CreateOpts) (*client.Client, error) {
 | 
						|
	opt := client.WithStart(binary, grpcAddress, debug)
 | 
						|
	if !remote {
 | 
						|
		opt = client.WithLocal(b.events)
 | 
						|
	}
 | 
						|
	var options runcopts.CreateOptions
 | 
						|
	if createOpts.Options != nil {
 | 
						|
		v, err := typeurl.UnmarshalAny(createOpts.Options)
 | 
						|
		if err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
		options = *v.(*runcopts.CreateOptions)
 | 
						|
	}
 | 
						|
	return client.New(ctx, client.Config{
 | 
						|
		Address:    b.shimAddress(),
 | 
						|
		Path:       b.path,
 | 
						|
		Namespace:  b.namespace,
 | 
						|
		CgroupPath: options.ShimCgroup,
 | 
						|
	}, opt)
 | 
						|
}
 | 
						|
 | 
						|
// Connect reconnects to an existing shim
 | 
						|
func (b *bundle) Connect(ctx context.Context, remote bool) (*client.Client, error) {
 | 
						|
	opt := client.WithConnect
 | 
						|
	if !remote {
 | 
						|
		opt = client.WithLocal(b.events)
 | 
						|
	}
 | 
						|
	return client.New(ctx, client.Config{
 | 
						|
		Address:   b.shimAddress(),
 | 
						|
		Path:      b.path,
 | 
						|
		Namespace: b.namespace,
 | 
						|
	}, opt)
 | 
						|
}
 | 
						|
 | 
						|
// Delete deletes the bundle from disk
 | 
						|
func (b *bundle) Delete() error {
 | 
						|
	return os.RemoveAll(b.path)
 | 
						|
}
 | 
						|
 | 
						|
func (b *bundle) shimAddress() string {
 | 
						|
	return filepath.Join(string(filepath.Separator), "containerd-shim", b.namespace, b.id, "shim.sock")
 | 
						|
 | 
						|
}
 |