luet/pkg/installer/system.go

54 lines
1.5 KiB
Go
Raw Normal View History

2019-11-22 20:01:38 +00:00
package installer
import (
"github.com/hashicorp/go-multierror"
2020-11-08 20:14:19 +00:00
"github.com/mudler/luet/pkg/helpers"
. "github.com/mudler/luet/pkg/logger"
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
}
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
type templatedata map[string]interface{}
func (s *System) ExecuteFinalizers(packs []pkg.Package) error {
var errs error
2020-11-08 20:14:19 +00:00
executedFinalizer := map[string]bool{}
for _, p := range packs {
if helpers.Exists(p.Rel(tree.FinalizerFile)) {
out, err := helpers.RenderFiles(p.Rel(tree.FinalizerFile), p.Rel(tree.DefinitionFile), "")
if err != nil {
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
2020-11-08 20:14:19 +00:00
Info("Executing finalizer for " + p.HumanReadableString())
finalizer, err := NewLuetFinalizerFromYaml([]byte(out))
if err != nil {
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(s)
if err != nil {
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
}