mirror of
https://github.com/mudler/luet.git
synced 2025-07-19 09:49:28 +00:00
Allow to push images in create-repo
Add also the --force flag to allow image overwrite Related to #169
This commit is contained in:
parent
d9286a1a1e
commit
ad455edafc
@ -67,6 +67,10 @@ Create a repository from the metadata description defined in the luet.yaml confi
|
|||||||
viper.BindPFlag("meta-filename", cmd.Flags().Lookup("meta-filename"))
|
viper.BindPFlag("meta-filename", cmd.Flags().Lookup("meta-filename"))
|
||||||
viper.BindPFlag("reset-revision", cmd.Flags().Lookup("reset-revision"))
|
viper.BindPFlag("reset-revision", cmd.Flags().Lookup("reset-revision"))
|
||||||
viper.BindPFlag("repo", cmd.Flags().Lookup("repo"))
|
viper.BindPFlag("repo", cmd.Flags().Lookup("repo"))
|
||||||
|
|
||||||
|
viper.BindPFlag("force-push", cmd.Flags().Lookup("force-push"))
|
||||||
|
viper.BindPFlag("push-images", cmd.Flags().Lookup("push-images"))
|
||||||
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
var err error
|
var err error
|
||||||
@ -90,6 +94,8 @@ Create a repository from the metadata description defined in the luet.yaml confi
|
|||||||
treeFile := installer.NewDefaultTreeRepositoryFile()
|
treeFile := installer.NewDefaultTreeRepositoryFile()
|
||||||
metaFile := installer.NewDefaultMetaRepositoryFile()
|
metaFile := installer.NewDefaultMetaRepositoryFile()
|
||||||
compilerBackend := backend.NewBackend(backendType)
|
compilerBackend := backend.NewBackend(backendType)
|
||||||
|
force := viper.GetBool("force-push")
|
||||||
|
imagePush := viper.GetBool("push-images")
|
||||||
|
|
||||||
if source_repo != "" {
|
if source_repo != "" {
|
||||||
// Search for system repository
|
// Search for system repository
|
||||||
@ -112,11 +118,11 @@ Create a repository from the metadata description defined in the luet.yaml confi
|
|||||||
lrepo.Priority,
|
lrepo.Priority,
|
||||||
packages,
|
packages,
|
||||||
treePaths,
|
treePaths,
|
||||||
pkg.NewInMemoryDatabase(false), compilerBackend, dst)
|
pkg.NewInMemoryDatabase(false), compilerBackend, dst, imagePush, force)
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
repo, err = installer.GenerateRepository(name, descr, t, urls, 1, packages,
|
repo, err = installer.GenerateRepository(name, descr, t, urls, 1, packages,
|
||||||
treePaths, pkg.NewInMemoryDatabase(false), compilerBackend, dst)
|
treePaths, pkg.NewInMemoryDatabase(false), compilerBackend, dst, imagePush, force)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -165,6 +171,9 @@ func init() {
|
|||||||
createrepoCmd.Flags().String("repo", "", "Use repository defined in configuration.")
|
createrepoCmd.Flags().String("repo", "", "Use repository defined in configuration.")
|
||||||
createrepoCmd.Flags().String("backend", "docker", "backend used (docker,img)")
|
createrepoCmd.Flags().String("backend", "docker", "backend used (docker,img)")
|
||||||
|
|
||||||
|
createrepoCmd.Flags().Bool("force-push", false, "Force overwrite of docker images if already present")
|
||||||
|
createrepoCmd.Flags().Bool("push-images", false, "Enable/Disable docker image push for docker repositories")
|
||||||
|
|
||||||
createrepoCmd.Flags().String("tree-compression", "gzip", "Compression alg: none, gzip, zstd")
|
createrepoCmd.Flags().String("tree-compression", "gzip", "Compression alg: none, gzip, zstd")
|
||||||
createrepoCmd.Flags().String("tree-filename", installer.TREE_TARBALL, "Repository tree filename")
|
createrepoCmd.Flags().String("tree-filename", installer.TREE_TARBALL, "Repository tree filename")
|
||||||
createrepoCmd.Flags().String("meta-compression", "none", "Compression alg: none, gzip, zstd")
|
createrepoCmd.Flags().String("meta-compression", "none", "Compression alg: none, gzip, zstd")
|
||||||
|
@ -65,6 +65,8 @@ type LuetSystemRepository struct {
|
|||||||
Tree tree.Builder `json:"-"`
|
Tree tree.Builder `json:"-"`
|
||||||
RepositoryFiles map[string]LuetRepositoryFile `json:"repo_files"`
|
RepositoryFiles map[string]LuetRepositoryFile `json:"repo_files"`
|
||||||
Backend compiler.CompilerBackend `json:"-"`
|
Backend compiler.CompilerBackend `json:"-"`
|
||||||
|
PushImages bool `json:"-"`
|
||||||
|
ForcePush bool `json:"-"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type LuetSystemRepositorySerialized struct {
|
type LuetSystemRepositorySerialized struct {
|
||||||
@ -184,7 +186,7 @@ func (f *LuetRepositoryFile) GetChecksums() compiler.Checksums {
|
|||||||
|
|
||||||
func GenerateRepository(name, descr, t string, urls []string,
|
func GenerateRepository(name, descr, t string, urls []string,
|
||||||
priority int, src string, treesDir []string, db pkg.PackageDatabase,
|
priority int, src string, treesDir []string, db pkg.PackageDatabase,
|
||||||
b compiler.CompilerBackend, imagePrefix string) (Repository, error) {
|
b compiler.CompilerBackend, imagePrefix string, pushImages, force bool) (Repository, error) {
|
||||||
|
|
||||||
tr := tree.NewInstallerRecipe(db)
|
tr := tree.NewInstallerRecipe(db)
|
||||||
|
|
||||||
@ -205,7 +207,7 @@ func GenerateRepository(name, descr, t string, urls []string,
|
|||||||
}
|
}
|
||||||
|
|
||||||
case DockerRepositoryType:
|
case DockerRepositoryType:
|
||||||
art, err = generatePackageImages(b, imagePrefix, src, tr.GetDatabase())
|
art, err = generatePackageImages(b, imagePrefix, src, tr.GetDatabase(), pushImages, force)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -213,7 +215,7 @@ func GenerateRepository(name, descr, t string, urls []string,
|
|||||||
|
|
||||||
repo := NewLuetSystemRepository(
|
repo := NewLuetSystemRepository(
|
||||||
config.NewLuetRepository(name, t, descr, urls, priority, true, false),
|
config.NewLuetRepository(name, t, descr, urls, priority, true, false),
|
||||||
art, tr)
|
art, tr, pushImages, force)
|
||||||
repo.SetBackend(b)
|
repo.SetBackend(b)
|
||||||
return repo, nil
|
return repo, nil
|
||||||
}
|
}
|
||||||
@ -225,12 +227,14 @@ func NewSystemRepository(repo config.LuetRepository) Repository {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewLuetSystemRepository(repo *config.LuetRepository, art []compiler.Artifact, builder tree.Builder) Repository {
|
func NewLuetSystemRepository(repo *config.LuetRepository, art []compiler.Artifact, builder tree.Builder, pushImages, force bool) Repository {
|
||||||
return &LuetSystemRepository{
|
return &LuetSystemRepository{
|
||||||
LuetRepository: repo,
|
LuetRepository: repo,
|
||||||
Index: art,
|
Index: art,
|
||||||
Tree: builder,
|
Tree: builder,
|
||||||
RepositoryFiles: map[string]LuetRepositoryFile{},
|
RepositoryFiles: map[string]LuetRepositoryFile{},
|
||||||
|
PushImages: pushImages,
|
||||||
|
ForcePush: force,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -264,7 +268,15 @@ func NewLuetSystemRepositoryFromYaml(data []byte, db pkg.PackageDatabase) (Repos
|
|||||||
return r, err
|
return r, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func generatePackageImages(b compiler.CompilerBackend, imagePrefix, path string, db pkg.PackageDatabase) ([]compiler.Artifact, error) {
|
func pushImage(b compiler.CompilerBackend, image string, force bool) error {
|
||||||
|
if b.ImageAvailable(image) && !force {
|
||||||
|
Debug("Image", image, "already present, skipping")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return b.Push(compiler.CompilerBackendOptions{ImageName: image})
|
||||||
|
}
|
||||||
|
|
||||||
|
func generatePackageImages(b compiler.CompilerBackend, imagePrefix, path string, db pkg.PackageDatabase, imagePush, force bool) ([]compiler.Artifact, error) {
|
||||||
|
|
||||||
var art []compiler.Artifact
|
var art []compiler.Artifact
|
||||||
var ff = func(currentpath string, info os.FileInfo, err error) error {
|
var ff = func(currentpath string, info os.FileInfo, err error) error {
|
||||||
@ -291,12 +303,17 @@ func generatePackageImages(b compiler.CompilerBackend, imagePrefix, path string,
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
Info("Generating final image", imagePrefix+artifact.GetCompileSpec().GetPackage().GetPackageImageName(),
|
packageImage := imagePrefix + artifact.GetCompileSpec().GetPackage().GetPackageImageName()
|
||||||
|
Info("Generating final image", packageImage,
|
||||||
"for package ", artifact.GetCompileSpec().GetPackage().HumanReadableString())
|
"for package ", artifact.GetCompileSpec().GetPackage().HumanReadableString())
|
||||||
if opts, err := artifact.GenerateFinalImage(imagePrefix+artifact.GetCompileSpec().GetPackage().GetPackageImageName(), b, true); err != nil {
|
if opts, err := artifact.GenerateFinalImage(packageImage, b, true); err != nil {
|
||||||
return errors.Wrap(err, "Failed generating metadata tree"+opts.ImageName)
|
return errors.Wrap(err, "Failed generating metadata tree"+opts.ImageName)
|
||||||
}
|
}
|
||||||
// TODO: Push image (check if exists first, and avoid to re-push the same images, unless --force is passed)
|
if imagePush {
|
||||||
|
if err := pushImage(b, packageImage, force); err != nil {
|
||||||
|
return errors.Wrapf(err, "Failed while pushing image: '%s'", packageImage)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
art = append(art, artifact)
|
art = append(art, artifact)
|
||||||
|
|
||||||
@ -685,7 +702,11 @@ func (r *LuetSystemRepository) genDockerRepo(imagePrefix string, resetRevision,
|
|||||||
if opts, err := a.GenerateFinalImage(imageTree, r.GetBackend(), false); err != nil {
|
if opts, err := a.GenerateFinalImage(imageTree, r.GetBackend(), false); err != nil {
|
||||||
return errors.Wrap(err, "Failed generating metadata tree "+opts.ImageName)
|
return errors.Wrap(err, "Failed generating metadata tree "+opts.ImageName)
|
||||||
}
|
}
|
||||||
// TODO: Push imageTree
|
if r.ForcePush {
|
||||||
|
if err := pushImage(r.GetBackend(), imageTree, true); err != nil {
|
||||||
|
return errors.Wrapf(err, "Failed while pushing image: '%s'", imageTree)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Create Metadata struct and serialized repository
|
// Create Metadata struct and serialized repository
|
||||||
meta, serialized := r.Serialize()
|
meta, serialized := r.Serialize()
|
||||||
@ -736,8 +757,11 @@ func (r *LuetSystemRepository) genDockerRepo(imagePrefix string, resetRevision,
|
|||||||
if opts, err := a.GenerateFinalImage(imageMetaTree, r.GetBackend(), false); err != nil {
|
if opts, err := a.GenerateFinalImage(imageMetaTree, r.GetBackend(), false); err != nil {
|
||||||
return errors.Wrap(err, "Failed generating metadata tree"+opts.ImageName)
|
return errors.Wrap(err, "Failed generating metadata tree"+opts.ImageName)
|
||||||
}
|
}
|
||||||
|
if r.ForcePush {
|
||||||
// TODO: Push image meta tree
|
if err := pushImage(r.GetBackend(), imageMetaTree, true); err != nil {
|
||||||
|
return errors.Wrapf(err, "Failed while pushing image: '%s'", imageMetaTree)
|
||||||
|
}
|
||||||
|
}
|
||||||
data, err := yaml.Marshal(serialized)
|
data, err := yaml.Marshal(serialized)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -757,7 +781,11 @@ func (r *LuetSystemRepository) genDockerRepo(imagePrefix string, resetRevision,
|
|||||||
if opts, err := a.GenerateFinalImage(imageRepo, r.GetBackend(), false); err != nil {
|
if opts, err := a.GenerateFinalImage(imageRepo, r.GetBackend(), false); err != nil {
|
||||||
return errors.Wrap(err, "Failed generating repository image"+opts.ImageName)
|
return errors.Wrap(err, "Failed generating repository image"+opts.ImageName)
|
||||||
}
|
}
|
||||||
// TODO: Push image meta tree
|
if r.ForcePush {
|
||||||
|
if err := pushImage(r.GetBackend(), imageRepo, true); err != nil {
|
||||||
|
return errors.Wrapf(err, "Failed while pushing image: '%s'", imageRepo)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bus.Manager.Publish(bus.EventRepositoryPostBuild, struct {
|
bus.Manager.Publish(bus.EventRepositoryPostBuild, struct {
|
||||||
Repo LuetSystemRepository
|
Repo LuetSystemRepository
|
||||||
@ -790,8 +818,14 @@ func (r *LuetSystemRepository) Client() Client {
|
|||||||
Urls: r.GetUrls(),
|
Urls: r.GetUrls(),
|
||||||
Authentication: r.GetAuthentication(),
|
Authentication: r.GetAuthentication(),
|
||||||
})
|
})
|
||||||
}
|
|
||||||
|
|
||||||
|
case DockerRepositoryType:
|
||||||
|
return client.NewDockerClient(
|
||||||
|
client.RepoData{
|
||||||
|
Urls: r.GetUrls(),
|
||||||
|
Authentication: r.GetAuthentication(),
|
||||||
|
})
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user