vendor: github.com/moby/buildkit 6bd81372ad6f (v0.13.0-dev)

full diff: 6bd81372ad...d6e142600e

Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
Sebastiaan van Stijn
2024-02-05 18:09:06 +01:00
parent 43ed470208
commit 7b3c4fc714
9 changed files with 113 additions and 8 deletions

View File

@ -58,3 +58,23 @@ func (s Set) Allowed(e Entitlement) bool {
_, ok := s[e]
return ok
}
func (s Set) Check(v Values) error {
if v.NetworkHost {
if !s.Allowed(EntitlementNetworkHost) {
return errors.Errorf("%s is not allowed", EntitlementNetworkHost)
}
}
if v.SecurityInsecure {
if !s.Allowed(EntitlementSecurityInsecure) {
return errors.Errorf("%s is not allowed", EntitlementSecurityInsecure)
}
}
return nil
}
type Values struct {
NetworkHost bool
SecurityInsecure bool
}

View File

@ -96,6 +96,15 @@ func ParseURL(remote string) (*GitURL, error) {
return nil, ErrUnknownProtocol
}
func IsGitTransport(remote string) bool {
if proto := protoRegexp.FindString(remote); proto != "" {
proto = strings.ToLower(strings.TrimSuffix(proto, "://"))
_, ok := supportedProtos[proto]
return ok
}
return sshutil.IsImplicitSSHTransport(remote)
}
func fromURL(url *url.URL) *GitURL {
withoutFragment := *url
withoutFragment.Fragment = ""

View File

@ -2,10 +2,12 @@ package leaseutil
import (
"context"
"sync"
"time"
"github.com/containerd/containerd/leases"
"github.com/containerd/containerd/namespaces"
"github.com/pkg/errors"
)
func WithLease(ctx context.Context, ls leases.Manager, opts ...leases.Opt) (context.Context, func(context.Context) error, error) {
@ -16,15 +18,66 @@ func WithLease(ctx context.Context, ls leases.Manager, opts ...leases.Opt) (cont
}, nil
}
l, err := ls.Create(ctx, append([]leases.Opt{leases.WithRandomID(), leases.WithExpiration(time.Hour)}, opts...)...)
lr, ctx, err := NewLease(ctx, ls, opts...)
if err != nil {
return nil, nil, err
}
return ctx, func(ctx context.Context) error {
return ls.Delete(ctx, lr.l)
}, nil
}
func NewLease(ctx context.Context, lm leases.Manager, opts ...leases.Opt) (*LeaseRef, context.Context, error) {
l, err := lm.Create(ctx, append([]leases.Opt{leases.WithRandomID(), leases.WithExpiration(time.Hour)}, opts...)...)
if err != nil {
return nil, nil, err
}
ctx = leases.WithLease(ctx, l.ID)
return ctx, func(ctx context.Context) error {
return ls.Delete(ctx, l)
}, nil
return &LeaseRef{lm: lm, l: l}, ctx, nil
}
type LeaseRef struct {
lm leases.Manager
l leases.Lease
once sync.Once
resources []leases.Resource
err error
}
func (l *LeaseRef) Discard() error {
return l.lm.Delete(context.Background(), l.l)
}
func (l *LeaseRef) Adopt(ctx context.Context) error {
l.once.Do(func() {
resources, err := l.lm.ListResources(ctx, l.l)
if err != nil {
l.err = err
return
}
l.resources = resources
})
if l.err != nil {
return l.err
}
currentID, ok := leases.FromContext(ctx)
if !ok {
return errors.Errorf("missing lease requirement for adopt")
}
for _, r := range l.resources {
if err := l.lm.AddResource(ctx, leases.Lease{ID: currentID}, r); err != nil {
return err
}
}
if len(l.resources) == 0 {
l.Discard()
return nil
}
go l.Discard()
return nil
}
func MakeTemporary(l *leases.Lease) error {