mirror of
https://github.com/mudler/LocalAI.git
synced 2026-01-04 09:40:32 -06:00
83 lines
2.0 KiB
Go
83 lines
2.0 KiB
Go
package oci
|
|
|
|
import (
|
|
"io"
|
|
"os"
|
|
|
|
containerdCompression "github.com/containerd/containerd/archive/compression"
|
|
"github.com/google/go-containerregistry/pkg/name"
|
|
v1 "github.com/google/go-containerregistry/pkg/v1"
|
|
"github.com/google/go-containerregistry/pkg/v1/empty"
|
|
"github.com/google/go-containerregistry/pkg/v1/mutate"
|
|
"github.com/google/go-containerregistry/pkg/v1/tarball"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
func imageFromTar(imagename, architecture, OS string, opener func() (io.ReadCloser, error)) (name.Reference, v1.Image, error) {
|
|
newRef, err := name.ParseReference(imagename)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
layer, err := tarball.LayerFromOpener(opener)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
baseImage := empty.Image
|
|
cfg, err := baseImage.ConfigFile()
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
cfg.Architecture = architecture
|
|
cfg.OS = OS
|
|
|
|
baseImage, err = mutate.ConfigFile(baseImage, cfg)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
img, err := mutate.Append(baseImage, mutate.Addendum{
|
|
Layer: layer,
|
|
History: v1.History{
|
|
CreatedBy: "localai",
|
|
Comment: "Custom image",
|
|
},
|
|
})
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
return newRef, img, nil
|
|
}
|
|
|
|
// CreateTar a imagetarball from a standard tarball
|
|
func CreateTar(srctar, dstimageTar, imagename, architecture, OS string) error {
|
|
|
|
dstFile, err := os.Create(dstimageTar)
|
|
if err != nil {
|
|
return errors.Wrap(err, "Cannot create "+dstimageTar)
|
|
}
|
|
defer dstFile.Close()
|
|
|
|
newRef, img, err := imageFromTar(imagename, architecture, OS, func() (io.ReadCloser, error) {
|
|
f, err := os.Open(srctar)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "Cannot open "+srctar)
|
|
}
|
|
decompressed, err := containerdCompression.DecompressStream(f)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "Cannot open "+srctar)
|
|
}
|
|
|
|
return decompressed, nil
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// NOTE: We might also stream that back to the daemon with daemon.Write(tag, img)
|
|
return tarball.Write(newRef, img, dstFile)
|
|
|
|
}
|