oc-deploy/src/install/install.go

149 lines
4.1 KiB
Go
Raw Normal View History

2024-09-02 09:09:46 +02:00
package install
import (
"fmt"
"sync"
2024-09-02 13:43:11 +02:00
"os"
2024-09-02 09:09:46 +02:00
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
"oc-deploy/versionOc"
2024-09-02 09:09:46 +02:00
)
type InstallClass struct {
Version string
Workspace string
tools []tool.ToolData
toolsBin map[string]string
charts []chart.ChartRepoData
2024-09-09 09:38:43 +02:00
2024-09-09 16:17:02 +02:00
commandHelm helm.HelmCommand
commandKubectl kubectl.KubectlCommand
2024-09-02 09:09:46 +02:00
}
2024-09-02 13:43:11 +02:00
func (this *InstallClass) NewInstall() (string, error) {
2024-09-02 09:09:46 +02:00
// Extraction du fichier de version
dst := fmt.Sprintf("%s/oc.yml", this.Workspace)
2024-09-02 13:43:11 +02:00
log.Log().Debug().Msg(fmt.Sprintf("Check du fichier de version : %s", dst))
if _, err := os.Stat(dst); err == nil {
log.Log().Debug().Msg("Existe déjà")
version, err := versionOc.GetFromFile(dst)
2024-09-02 09:09:46 +02:00
if err != nil {
2024-09-02 13:43:11 +02:00
return "", err
2024-09-02 09:09:46 +02:00
}
2024-09-02 13:43:11 +02:00
this.Version = version
} else {
log.Log().Debug().Msg("Téléchargement du fichier de version")
2024-09-04 17:32:18 +02:00
// version, fileversion, err := versionOc.Get(this.Version)
version, fileversion, err := versionOc.GetFromOnline(this.Version)
2024-09-02 09:09:46 +02:00
if err != nil {
2024-09-02 13:43:11 +02:00
return "", err
2024-09-02 09:09:46 +02:00
}
2024-09-04 17:32:18 +02:00
this.Version = version
err = utils.CopyContentFile(fileversion, dst)
2024-09-02 13:43:11 +02:00
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
var err error
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-09 09:38:43 +02:00
bin_path, _ := this.getToolBin("helm")
fmt.Println("Install 67 bin_path", bin_path)
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,
ForceUpdate: v.Repository.ForceUpdate}
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
}