2024-09-02 09:09:46 +02:00
|
|
|
package install
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
log "oc-deploy/log_wrapper"
|
|
|
|
"oc-deploy/utils"
|
|
|
|
"oc-deploy/tool"
|
|
|
|
"oc-deploy/chart"
|
2024-09-02 13:43:11 +02:00
|
|
|
"oc-deploy/helm"
|
2024-09-02 09:09:46 +02:00
|
|
|
"oc-deploy/kubectl"
|
|
|
|
)
|
|
|
|
|
2024-09-02 13:43:11 +02:00
|
|
|
func (this *InstallClass) NewInstall() (string, error) {
|
2024-09-02 09:09:46 +02:00
|
|
|
|
2024-09-11 15:40:40 +02:00
|
|
|
// Extraction du fichier de la version
|
|
|
|
dst, err := this.extractVersion()
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
2024-09-02 09:09:46 +02:00
|
|
|
}
|
|
|
|
|
2024-09-02 13:43:11 +02:00
|
|
|
// Lecture du fichier de conf
|
2024-09-03 15:18:20 +02:00
|
|
|
this.tools, err = tool.FromConfigFile(dst)
|
|
|
|
if err != nil {
|
|
|
|
return dst, err
|
|
|
|
}
|
|
|
|
this.charts, _ = chart.FromConfigFile(dst)
|
|
|
|
if err != nil {
|
|
|
|
return dst, err
|
|
|
|
}
|
2024-09-02 09:09:46 +02:00
|
|
|
|
2024-09-02 13:43:11 +02:00
|
|
|
return dst, nil
|
2024-09-02 09:09:46 +02:00
|
|
|
}
|
|
|
|
|
2024-09-02 13:43:11 +02:00
|
|
|
|
2024-09-02 09:09:46 +02:00
|
|
|
func (this *InstallClass) ChartRepo() (error) {
|
|
|
|
|
|
|
|
for _, v := range this.charts {
|
2024-09-03 17:18:11 +02:00
|
|
|
if v.Repository.Name != "" {
|
|
|
|
log.Log().Info().Msg(fmt.Sprintf(" >> Helm Repo : %s", v.Repository.Name))
|
2024-09-09 09:38:43 +02:00
|
|
|
repo := helm.HelmRepo{Name: v.Repository.Name,
|
|
|
|
Repository: v.Repository.Url,
|
2024-09-13 12:53:28 +02:00
|
|
|
ForceUpdate: v.Repository.ForceUpdate,
|
|
|
|
Opts: v.Repository.Opts}
|
2024-09-09 09:38:43 +02:00
|
|
|
res, err := this.commandHelm.AddRepository(repo)
|
2024-09-03 17:18:11 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Log().Info().Msg(fmt.Sprintf(" << %s ", err))
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
log.Log().Info().Msg(fmt.Sprintf(" << %s ", res))
|
2024-09-02 09:09:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2024-09-03 17:26:10 +02:00
|
|
|
func (this *InstallClass) InstallCharts(modules []string) (error) {
|
2024-09-02 09:09:46 +02:00
|
|
|
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
|
|
|
|
for _, v := range this.charts {
|
|
|
|
for _, v1 := range v.Charts {
|
2024-09-09 12:11:44 +02:00
|
|
|
if len(modules) == 0 || utils.StringInSlice(v1.Name, modules) {
|
2024-09-03 17:26:10 +02:00
|
|
|
wg.Add(1)
|
2024-09-02 09:09:46 +02:00
|
|
|
|
2024-09-03 17:26:10 +02:00
|
|
|
go func() {
|
|
|
|
defer wg.Done()
|
2024-09-09 16:17:02 +02:00
|
|
|
this.installChart(v1)
|
2024-09-03 17:26:10 +02:00
|
|
|
} ()
|
|
|
|
}
|
2024-09-02 09:09:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
wg.Wait()
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-09-09 16:17:02 +02:00
|
|
|
func (this *InstallClass) installChart(chart chart.ChartData) {
|
2024-09-02 09:09:46 +02:00
|
|
|
|
|
|
|
log.Log().Info().Msg(fmt.Sprintf(" << Chart : %s ", chart.Name))
|
|
|
|
|
2024-09-09 16:17:02 +02:00
|
|
|
data := helm.HelmChart{Name: chart.Name,
|
|
|
|
Chart: chart.Chart,
|
|
|
|
Url: chart.Url,
|
|
|
|
Version: chart.Version,
|
|
|
|
Workspace: this.Workspace,
|
|
|
|
Opts: chart.Opts,
|
|
|
|
Values: chart.Values,
|
|
|
|
FileValues: chart.FileValues}
|
2024-09-02 09:09:46 +02:00
|
|
|
|
2024-09-09 16:17:02 +02:00
|
|
|
res, err := this.commandHelm.ChartInstall(data)
|
2024-09-02 09:09:46 +02:00
|
|
|
if err != nil {
|
2024-09-09 16:17:02 +02:00
|
|
|
log.Log().Error().Msg(fmt.Sprintf(" >> %s %s (%s)", data.Name, "KO", err))
|
2024-09-02 09:09:46 +02:00
|
|
|
return
|
|
|
|
}
|
2024-09-09 16:17:02 +02:00
|
|
|
log.Log().Info().Msg(fmt.Sprintf(" >> %s (%s)", data.Name, res))
|
2024-09-02 09:09:46 +02:00
|
|
|
|
2024-09-09 16:17:02 +02:00
|
|
|
ressources, _ := this.commandHelm.GetRessources(data)
|
2024-09-06 16:08:05 +02:00
|
|
|
|
|
|
|
for key, value := range ressources {
|
2024-09-09 16:17:02 +02:00
|
|
|
obj := kubectl.KubectlObject{Name: key, Kind: value}
|
|
|
|
err := this.commandKubectl.Wait(obj)
|
2024-09-06 16:08:05 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Log().Error().Msg(fmt.Sprintf(" >> %s/%s KO (%s)", chart.Name, key, err))
|
|
|
|
} else {
|
|
|
|
log.Log().Info().Msg(fmt.Sprintf(" >> %s/%s OK", chart.Name, key))
|
|
|
|
}
|
|
|
|
|
2024-09-02 09:09:46 +02:00
|
|
|
}
|
2024-09-06 16:08:05 +02:00
|
|
|
|
2024-09-02 09:09:46 +02:00
|
|
|
}
|