mirror of
https://github.com/mudler/luet.git
synced 2025-09-23 20:18:30 +00:00
🔧 Update modules
This commit is contained in:
103
vendor/github.com/google/go-containerregistry/pkg/v1/daemon/image.go
generated
vendored
103
vendor/github.com/google/go-containerregistry/pkg/v1/daemon/image.go
generated
vendored
@@ -24,8 +24,18 @@ import (
|
||||
"github.com/google/go-containerregistry/pkg/name"
|
||||
v1 "github.com/google/go-containerregistry/pkg/v1"
|
||||
"github.com/google/go-containerregistry/pkg/v1/tarball"
|
||||
"github.com/google/go-containerregistry/pkg/v1/types"
|
||||
)
|
||||
|
||||
type image struct {
|
||||
ref name.Reference
|
||||
opener *imageOpener
|
||||
tarballImage v1.Image
|
||||
|
||||
once sync.Once
|
||||
err error
|
||||
}
|
||||
|
||||
type imageOpener struct {
|
||||
ref name.Reference
|
||||
ctx context.Context
|
||||
@@ -85,5 +95,96 @@ func Image(ref name.Reference, options ...Option) (v1.Image, error) {
|
||||
ctx: o.ctx,
|
||||
}
|
||||
|
||||
return tarball.Image(i.opener(), nil)
|
||||
return &image{
|
||||
ref: ref,
|
||||
opener: i,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func (i *image) initialize() error {
|
||||
// Don't re-initialize tarball if already initialized.
|
||||
if i.tarballImage == nil {
|
||||
i.once.Do(func() {
|
||||
i.tarballImage, i.err = tarball.Image(i.opener.opener(), nil)
|
||||
})
|
||||
}
|
||||
return i.err
|
||||
}
|
||||
|
||||
func (i *image) Layers() ([]v1.Layer, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.Layers()
|
||||
}
|
||||
|
||||
func (i *image) MediaType() (types.MediaType, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return "", err
|
||||
}
|
||||
return i.tarballImage.MediaType()
|
||||
}
|
||||
|
||||
func (i *image) Size() (int64, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return 0, err
|
||||
}
|
||||
return i.tarballImage.Size()
|
||||
}
|
||||
|
||||
func (i *image) ConfigName() (v1.Hash, error) {
|
||||
res, _, err := i.opener.client.ImageInspectWithRaw(i.opener.ctx, i.ref.String())
|
||||
if err != nil {
|
||||
return v1.Hash{}, err
|
||||
}
|
||||
return v1.NewHash(res.ID)
|
||||
}
|
||||
|
||||
func (i *image) ConfigFile() (*v1.ConfigFile, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.ConfigFile()
|
||||
}
|
||||
|
||||
func (i *image) RawConfigFile() ([]byte, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.RawConfigFile()
|
||||
}
|
||||
|
||||
func (i *image) Digest() (v1.Hash, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return v1.Hash{}, err
|
||||
}
|
||||
return i.tarballImage.Digest()
|
||||
}
|
||||
|
||||
func (i *image) Manifest() (*v1.Manifest, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.Manifest()
|
||||
}
|
||||
|
||||
func (i *image) RawManifest() ([]byte, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.RawManifest()
|
||||
}
|
||||
|
||||
func (i *image) LayerByDigest(h v1.Hash) (v1.Layer, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.LayerByDigest(h)
|
||||
}
|
||||
|
||||
func (i *image) LayerByDiffID(h v1.Hash) (v1.Layer, error) {
|
||||
if err := i.initialize(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return i.tarballImage.LayerByDiffID(h)
|
||||
}
|
||||
|
1
vendor/github.com/google/go-containerregistry/pkg/v1/daemon/options.go
generated
vendored
1
vendor/github.com/google/go-containerregistry/pkg/v1/daemon/options.go
generated
vendored
@@ -99,4 +99,5 @@ type Client interface {
|
||||
ImageSave(context.Context, []string) (io.ReadCloser, error)
|
||||
ImageLoad(context.Context, io.Reader, bool) (types.ImageLoadResponse, error)
|
||||
ImageTag(context.Context, string, string) error
|
||||
ImageInspectWithRaw(context.Context, string) (types.ImageInspect, []byte, error)
|
||||
}
|
||||
|
4
vendor/github.com/google/go-containerregistry/pkg/v1/daemon/write.go
generated
vendored
4
vendor/github.com/google/go-containerregistry/pkg/v1/daemon/write.go
generated
vendored
@@ -49,13 +49,13 @@ func Write(tag name.Tag, img v1.Image, options ...Option) (string, error) {
|
||||
// write the image in docker save format first, then load it
|
||||
resp, err := o.client.ImageLoad(o.ctx, pr, false)
|
||||
if err != nil {
|
||||
return "", fmt.Errorf("error loading image: %v", err)
|
||||
return "", fmt.Errorf("error loading image: %w", err)
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
b, err := ioutil.ReadAll(resp.Body)
|
||||
response := string(b)
|
||||
if err != nil {
|
||||
return response, fmt.Errorf("error reading load response body: %v", err)
|
||||
return response, fmt.Errorf("error reading load response body: %w", err)
|
||||
}
|
||||
return response, nil
|
||||
}
|
||||
|
Reference in New Issue
Block a user