luet/pkg/installer/system.go

88 lines
2.3 KiB
Go
Raw Normal View History

2019-11-22 20:01:38 +00:00
package installer
import (
"sync"
"github.com/hashicorp/go-multierror"
"github.com/mudler/luet/pkg/api/core/types"
2020-11-08 20:14:19 +00:00
"github.com/mudler/luet/pkg/helpers"
fileHelper "github.com/mudler/luet/pkg/helpers/file"
2019-11-22 20:01:38 +00:00
pkg "github.com/mudler/luet/pkg/package"
2020-11-08 20:14:19 +00:00
"github.com/mudler/luet/pkg/tree"
2019-11-22 20:01:38 +00:00
)
type System struct {
Database pkg.PackageDatabase
Target string
fileIndex map[string]pkg.Package
sync.Mutex
2019-11-22 20:01:38 +00:00
}
2020-04-04 12:29:08 +00:00
func (s *System) World() (pkg.Packages, error) {
2019-11-29 18:01:52 +00:00
return s.Database.World(), nil
2019-11-22 20:01:38 +00:00
}
2020-11-08 20:14:19 +00:00
func (s *System) ExecuteFinalizers(ctx *types.Context, packs []pkg.Package) error {
var errs error
2020-11-08 20:14:19 +00:00
executedFinalizer := map[string]bool{}
for _, p := range packs {
if fileHelper.Exists(p.Rel(tree.FinalizerFile)) {
out, err := helpers.RenderFiles(helpers.ChartFile(p.Rel(tree.FinalizerFile)), p.Rel(pkg.PackageDefinitionFile))
if err != nil {
ctx.Warning("Failed rendering finalizer for ", p.HumanReadableString(), err.Error())
errs = multierror.Append(errs, err)
continue
2020-11-08 20:14:19 +00:00
}
if _, exists := executedFinalizer[p.GetFingerPrint()]; !exists {
executedFinalizer[p.GetFingerPrint()] = true
ctx.Info("Executing finalizer for " + p.HumanReadableString())
2020-11-08 20:14:19 +00:00
finalizer, err := NewLuetFinalizerFromYaml([]byte(out))
if err != nil {
ctx.Warning("Failed reading finalizer for ", p.HumanReadableString(), err.Error())
errs = multierror.Append(errs, err)
continue
2020-11-08 20:14:19 +00:00
}
err = finalizer.RunInstall(ctx, s)
if err != nil {
ctx.Warning("Failed running finalizer for ", p.HumanReadableString(), err.Error())
errs = multierror.Append(errs, err)
continue
2020-11-08 20:14:19 +00:00
}
}
}
}
return errs
2020-11-08 20:14:19 +00:00
}
func (s *System) buildFileIndex() {
s.Lock()
defer s.Unlock()
// Check if cache is empty or if it got modified
if s.fileIndex == nil { //|| len(s.Database.GetPackages()) != len(s.fileIndex) {
s.fileIndex = make(map[string]pkg.Package)
for _, p := range s.Database.World() {
files, _ := s.Database.GetPackageFiles(p)
for _, f := range files {
s.fileIndex[f] = p
}
}
}
}
func (s *System) Clean() {
s.Lock()
defer s.Unlock()
s.fileIndex = nil
}
func (s *System) ExistsPackageFile(file string) (bool, pkg.Package, error) {
s.buildFileIndex()
s.Lock()
defer s.Unlock()
if p, exists := s.fileIndex[file]; exists {
return exists, p, nil
}
return false, nil, nil
}