|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"github.com/moby/buildkit/client/llb"
|
|
|
|
"github.com/moby/buildkit/solver/pb"
|
|
|
|
"github.com/moby/buildkit/solver/result"
|
|
|
|
"github.com/moby/buildkit/util/apicaps"
|
|
|
|
digest "github.com/opencontainers/go-digest"
|
|
|
|
ocispecs "github.com/opencontainers/image-spec/specs-go/v1"
|
|
|
|
fstypes "github.com/tonistiigi/fsutil/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Result = result.Result[Reference]
|
|
|
|
|
|
|
|
type BuildFunc func(context.Context, Client) (*Result, error)
|
|
|
|
|
|
|
|
func NewResult() *Result {
|
|
|
|
return &Result{}
|
|
|
|
}
|
|
|
|
|
|
|
|
type Client interface {
|
|
|
|
Solve(ctx context.Context, req SolveRequest) (*Result, error)
|
|
|
|
ResolveImageConfig(ctx context.Context, ref string, opt llb.ResolveImageConfigOpt) (digest.Digest, []byte, error)
|
|
|
|
BuildOpts() BuildOpts
|
|
|
|
Inputs(ctx context.Context) (map[string]llb.State, error)
|
|
|
|
NewContainer(ctx context.Context, req NewContainerRequest) (Container, error)
|
|
|
|
Warn(ctx context.Context, dgst digest.Digest, msg string, opts WarnOpts) error
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewContainerRequest encapsulates the requirements for a client to define a
|
|
|
|
// new container, without defining the initial process.
|
|
|
|
type NewContainerRequest struct {
|
|
|
|
Mounts []Mount
|
|
|
|
NetMode pb.NetMode
|
|
|
|
ExtraHosts []*pb.HostIP
|
|
|
|
Platform *pb.Platform
|
|
|
|
Constraints *pb.WorkerConstraints
|
|
|
|
}
|
|
|
|
|
|
|
|
// Mount allows clients to specify a filesystem mount. A Reference to a
|
|
|
|
// previously solved Result is required.
|
|
|
|
type Mount struct {
|
|
|
|
Selector string
|
|
|
|
Dest string
|
|
|
|
ResultID string
|
|
|
|
Ref Reference
|
|
|
|
Readonly bool
|
|
|
|
MountType pb.MountType
|
|
|
|
CacheOpt *pb.CacheOpt
|
|
|
|
SecretOpt *pb.SecretOpt
|
|
|
|
SSHOpt *pb.SSHOpt
|
|
|
|
}
|
|
|
|
|
|
|
|
// Container is used to start new processes inside a container and release the
|
|
|
|
// container resources when done.
|
|
|
|
type Container interface {
|
|
|
|
Start(context.Context, StartRequest) (ContainerProcess, error)
|
|
|
|
Release(context.Context) error
|
|
|
|
}
|
|
|
|
|
|
|
|
// StartRequest encapsulates the arguments to define a process within a
|
|
|
|
// container.
|
|
|
|
type StartRequest struct {
|
|
|
|
Args []string
|
|
|
|
Env []string
|
|
|
|
User string
|
|
|
|
Cwd string
|
|
|
|
Tty bool
|
|
|
|
Stdin io.ReadCloser
|
|
|
|
Stdout, Stderr io.WriteCloser
|
|
|
|
SecurityMode pb.SecurityMode
|
|
|
|
}
|
|
|
|
|
|
|
|
// WinSize is same as executor.WinSize, copied here to prevent circular package
|
|
|
|
// dependencies.
|
|
|
|
type WinSize struct {
|
|
|
|
Rows uint32
|
|
|
|
Cols uint32
|
|
|
|
}
|
|
|
|
|
|
|
|
// ContainerProcess represents a process within a container.
|
|
|
|
type ContainerProcess interface {
|
|
|
|
Wait() error
|
|
|
|
Resize(ctx context.Context, size WinSize) error
|
|
|
|
Signal(ctx context.Context, sig syscall.Signal) error
|
|
|
|
}
|
|
|
|
|
|
|
|
type Reference interface {
|
|
|
|
ToState() (llb.State, error)
|
|
|
|
Evaluate(ctx context.Context) error
|
|
|
|
ReadFile(ctx context.Context, req ReadRequest) ([]byte, error)
|
|
|
|
StatFile(ctx context.Context, req StatRequest) (*fstypes.Stat, error)
|
|
|
|
ReadDir(ctx context.Context, req ReadDirRequest) ([]*fstypes.Stat, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
type ReadRequest struct {
|
|
|
|
Filename string
|
|
|
|
Range *FileRange
|
|
|
|
}
|
|
|
|
|
|
|
|
type FileRange struct {
|
|
|
|
Offset int
|
|
|
|
Length int
|
|
|
|
}
|
|
|
|
|
|
|
|
type ReadDirRequest struct {
|
|
|
|
Path string
|
|
|
|
IncludePattern string
|
|
|
|
}
|
|
|
|
|
|
|
|
type StatRequest struct {
|
|
|
|
Path string
|
|
|
|
}
|
|
|
|
|
|
|
|
// SolveRequest is same as frontend.SolveRequest but avoiding dependency
|
|
|
|
type SolveRequest struct {
|
|
|
|
Evaluate bool
|
|
|
|
Definition *pb.Definition
|
|
|
|
Frontend string
|
|
|
|
FrontendOpt map[string]string
|
|
|
|
FrontendInputs map[string]*pb.Definition
|
|
|
|
CacheImports []CacheOptionsEntry
|
|
|
|
}
|
|
|
|
|
|
|
|
type CacheOptionsEntry struct {
|
|
|
|
Type string
|
|
|
|
Attrs map[string]string
|
|
|
|
}
|
|
|
|
|
|
|
|
type WorkerInfo struct {
|
|
|
|
ID string
|
|
|
|
Labels map[string]string
|
|
|
|
Platforms []ocispecs.Platform
|
|
|
|
}
|
|
|
|
|
|
|
|
type BuildOpts struct {
|
|
|
|
Opts map[string]string
|
|
|
|
SessionID string
|
|
|
|
Workers []WorkerInfo
|
|
|
|
Product string
|
|
|
|
LLBCaps apicaps.CapSet
|
|
|
|
Caps apicaps.CapSet
|
|
|
|
}
|
|
|
|
|
|
|
|
type WarnOpts struct {
|
|
|
|
Level int
|
|
|
|
SourceInfo *pb.SourceInfo
|
|
|
|
Range []*pb.Range
|
|
|
|
Detail [][]byte
|
|
|
|
URL string
|
|
|
|
}
|