WIP: Trying to diff
This commit is contained in:
		| @@ -19,7 +19,8 @@ func init() { | |||||||
| 	sync.Flags().StringP("config", "c", "config.yaml", "A path to the configuration file") | 	sync.Flags().StringP("config", "c", "config.yaml", "A path to the configuration file") | ||||||
| 	sync.Flags().String("workdir", "", "A path to the workdir. On the moment of running, it should be an empty dir") | 	sync.Flags().String("workdir", "", "A path to the workdir. On the moment of running, it should be an empty dir") | ||||||
| 	sync.Flags().String("ssh-key", "", "A path to the pricate ssh key") | 	sync.Flags().String("ssh-key", "", "A path to the pricate ssh key") | ||||||
| 	sync.Flags().Bool("dry-run", false, "If set to false, will no push changes to git") | 	sync.Flags().Bool("dry-run", false, "If set to false, will not push changes to git") | ||||||
|  | 	sync.Flags().Bool("diff", false, "If set to false, will show helm diffs for not preserved charts") | ||||||
| 	sync.Flags().String("sops-bin", "/usr/bin/sops", "A path to the sops binary in your system") | 	sync.Flags().String("sops-bin", "/usr/bin/sops", "A path to the sops binary in your system") | ||||||
|  |  | ||||||
| 	rootCmd.AddCommand(sync) | 	rootCmd.AddCommand(sync) | ||||||
| @@ -31,6 +32,7 @@ func syncCmd(cmd *cobra.Command, args []string) { | |||||||
| 	sshKey := cmd.Flag("ssh-key").Value.String() | 	sshKey := cmd.Flag("ssh-key").Value.String() | ||||||
| 	sopsBin := cmd.Flag("sops-bin").Value.String() | 	sopsBin := cmd.Flag("sops-bin").Value.String() | ||||||
| 	dryRun, err := cmd.Flags().GetBool("dry-run") | 	dryRun, err := cmd.Flags().GetBool("dry-run") | ||||||
|  | 	diff, err := cmd.Flags().GetBool("diff") | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		logrus.Fatal(err) | 		logrus.Fatal(err) | ||||||
| 	} | 	} | ||||||
| @@ -41,7 +43,7 @@ func syncCmd(cmd *cobra.Command, args []string) { | |||||||
| 	} | 	} | ||||||
| 	configObj.SopsBin = sopsBin | 	configObj.SopsBin = sopsBin | ||||||
|  |  | ||||||
| 	err = controller.Reconcile(workdir, sshKey, configObj, dryRun) | 	err = controller.Sync(workdir, sshKey, configObj, dryRun, diff) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		logrus.Fatal(err) | 		logrus.Fatal(err) | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -24,7 +24,7 @@ func ReadTheConfig(path string) (*config.Config, error) { | |||||||
| 	return conf, nil | 	return conf, nil | ||||||
| } | } | ||||||
|  |  | ||||||
| func Reconcile(definedWorkdirPath, sshKeyPath string, conf *config.Config, dry bool) error { | func Sync(definedWorkdirPath, sshKeyPath string, conf *config.Config, dry, diffArg bool) error { | ||||||
| 	// Start by creating a directory where everything should be happening | 	// Start by creating a directory where everything should be happening | ||||||
| 	configPath := filepath.Dir(conf.ConfigPath) | 	configPath := filepath.Dir(conf.ConfigPath) | ||||||
| 	workdirPath, err := workdir.CreateWorkdir(definedWorkdirPath) | 	workdirPath, err := workdir.CreateWorkdir(definedWorkdirPath) | ||||||
| @@ -88,6 +88,14 @@ func Reconcile(definedWorkdirPath, sshKeyPath string, conf *config.Config, dry b | |||||||
| 				return err | 				return err | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			if diffArg { | ||||||
|  | 				_, err := hh.PullChart(workdirPath, *release.RepositoryObj, release.Chart, release.Version) | ||||||
|  | 				if err != nil { | ||||||
|  | 					return err | ||||||
|  | 				} | ||||||
|  | 				hh.RenderChart(workdirPath, *release.RepositoryObj, release.Chart, release.Version) | ||||||
|  | 			} | ||||||
|  |  | ||||||
| 			if err := release.ValuesHandler(configPath); err != nil { | 			if err := release.ValuesHandler(configPath); err != nil { | ||||||
| 				return err | 				return err | ||||||
| 			} | 			} | ||||||
| @@ -105,6 +113,12 @@ func Reconcile(definedWorkdirPath, sshKeyPath string, conf *config.Config, dry b | |||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		if diffArg { | ||||||
|  | 			for _, releaseCurrent := range releasesCurrent { | ||||||
|  | 				hh.PullChart(workdirPath, *releaseCurrent.RepositoryObj, releaseCurrent.Chart, releaseCurrent.Version) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		// Compare releases from the lockfile to ones from the current cluster config | 		// Compare releases from the lockfile to ones from the current cluster config | ||||||
| 		diffReleases, err := diff.DiffReleases(releasesCurrent, cluster.ReleasesObj) | 		diffReleases, err := diff.DiffReleases(releasesCurrent, cluster.ReleasesObj) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
|   | |||||||
| @@ -8,7 +8,9 @@ import ( | |||||||
| 	"github.com/sirupsen/logrus" | 	"github.com/sirupsen/logrus" | ||||||
| 	"gopkg.in/yaml.v2" | 	"gopkg.in/yaml.v2" | ||||||
| 	"helm.sh/helm/v3/pkg/action" | 	"helm.sh/helm/v3/pkg/action" | ||||||
|  | 	"helm.sh/helm/v3/pkg/chart/loader" | ||||||
| 	"helm.sh/helm/v3/pkg/cli" | 	"helm.sh/helm/v3/pkg/cli" | ||||||
|  | 	"helm.sh/helm/v3/pkg/engine" | ||||||
| 	"helm.sh/helm/v3/pkg/getter" | 	"helm.sh/helm/v3/pkg/getter" | ||||||
| 	"helm.sh/helm/v3/pkg/registry" | 	"helm.sh/helm/v3/pkg/registry" | ||||||
| 	"helm.sh/helm/v3/pkg/repo" | 	"helm.sh/helm/v3/pkg/repo" | ||||||
| @@ -24,23 +26,32 @@ type ChartData struct { | |||||||
| 	Version string | 	Version string | ||||||
| } | } | ||||||
|  |  | ||||||
| func (h *Helm) FindLatestVersion(dir, chart string, repository repository.Repository) (version string, err error) { | func getDownloadDirPath(workdirPath string) string { | ||||||
| 	downloadDir := fmt.Sprintf("%s/.charts", dir) | 	return fmt.Sprintf("%s/.charts", workdirPath) | ||||||
| 	if err := os.MkdirAll(downloadDir, 0777); err != nil { | } | ||||||
|  |  | ||||||
|  | func getChartDirPath(downloadDirPath, repository, chart, version string) string { | ||||||
|  | 	return fmt.Sprintf("%s/%s-%s-%s", downloadDirPath, repository, chart, version) | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (h *Helm) PullChart(workdirPath string, repository repository.Repository, chart, version string) (path string, err error) { | ||||||
|  | 	downloadDirPath := getDownloadDirPath(workdirPath) | ||||||
|  | 	if err := os.MkdirAll(downloadDirPath, 0777); err != nil { | ||||||
| 		return "", err | 		return "", err | ||||||
| 	} | 	} | ||||||
| 	// If file doesn't exist |  | ||||||
| 	config := new(action.Configuration) | 	config := new(action.Configuration) | ||||||
| 	cl := cli.New() | 	cl := cli.New() | ||||||
| 	chartDir := fmt.Sprintf("%s/%s-%s", downloadDir, repository.Name, chart) | 	chartDir := getChartDirPath(downloadDirPath, repository.Name, chart, version) | ||||||
| 	_, err = os.Stat(chartDir) | 	_, err = os.Stat(chartDir) | ||||||
|  |  | ||||||
| 	if err != nil && !os.IsNotExist(err) { | 	if err != nil && !os.IsNotExist(err) { | ||||||
| 		return "", nil | 		return "", nil | ||||||
| 	} else if os.IsNotExist(err) { | 	} else if os.IsNotExist(err) { | ||||||
| 		if err := os.Mkdir(chartDir, 0777); err != nil { | 		if err := os.Mkdir(chartDir, 0777); err != nil { | ||||||
| 			return "", err | 			return "", err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		registry, err := registry.NewClient() | 		registry, err := registry.NewClient() | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return "", err | 			return "", err | ||||||
| @@ -72,16 +83,32 @@ func (h *Helm) FindLatestVersion(dir, chart string, repository repository.Reposi | |||||||
| 		if _, err = client.Run(chartRemote); err != nil { | 		if _, err = client.Run(chartRemote); err != nil { | ||||||
| 			return "", err | 			return "", err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 	} | 	} | ||||||
|  | 	path, err = getChartPathFromDir(chartDir) | ||||||
| 	showAction := action.NewShowWithConfig(action.ShowChart, config) |  | ||||||
|  |  | ||||||
| 	chartPath, err := getChartPathFromDir(chartDir) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return "", err | 		return "", err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	return path, nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (h *Helm) FindLatestVersion(workdirPath, chart string, repository repository.Repository) (version string, err error) { | ||||||
|  | 	downloadDirPath := getDownloadDirPath(workdirPath) | ||||||
|  | 	if err := os.MkdirAll(downloadDirPath, 0777); err != nil { | ||||||
|  | 		return "", err | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	config := new(action.Configuration) | ||||||
|  | 	cl := cli.New() | ||||||
|  | 	chartDir := getChartDirPath(downloadDirPath, repository.Name, chart, "latest") | ||||||
|  | 	chartPath, err := h.PullChart(workdirPath, repository, chart, "latest") | ||||||
|  | 	if err != nil { | ||||||
|  | 		return "", err | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	showAction := action.NewShowWithConfig(action.ShowChart, config) | ||||||
|  | 	action.New | ||||||
|  |  | ||||||
| 	res, err := showAction.LocateChart(fmt.Sprintf("%s/%s", chartDir, chartPath), cl) | 	res, err := showAction.LocateChart(fmt.Sprintf("%s/%s", chartDir, chartPath), cl) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return "", err | 		return "", err | ||||||
| @@ -96,17 +123,44 @@ func (h *Helm) FindLatestVersion(dir, chart string, repository repository.Reposi | |||||||
| 		return "", err | 		return "", err | ||||||
| 	} | 	} | ||||||
| 	logrus.Infof("the latest version of %s is %s", chart, chartData.Version) | 	logrus.Infof("the latest version of %s is %s", chart, chartData.Version) | ||||||
|  | 	versionedChartDir := getChartDirPath(downloadDirPath, repository.Name, chart, chartData.Version) | ||||||
|  | 	os.Rename(chartDir, versionedChartDir) | ||||||
| 	return chartData.Version, err | 	return chartData.Version, err | ||||||
| } | } | ||||||
|  |  | ||||||
| func getChartPathFromDir(dir string) (file string, err error) { | func (h *Helm) RenderChart(workdirPath string, repository repository.Repository, ch2art, version string) error { | ||||||
| 	files, err := os.ReadDir(dir) | 	downloadDirPath := getDownloadDirPath(workdirPath) | ||||||
|  | 	chartDirPath := getChartDirPath(downloadDirPath, repository.Name, ch2art, version) | ||||||
|  | 	chartPath, err := getChartPathFromDir(chartDirPath) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	logrus.Info(fmt.Sprintf("%s/%s", chartDirPath, chartPath)) | ||||||
|  | 	chartObj, err := loader.Load(fmt.Sprintf("%s/%s", chartDirPath, chartPath)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	config := new(action.Configuration) | ||||||
|  | 	client := action.NewInstall(config) | ||||||
|  | 	client.RepoURL = repository.URL | ||||||
|  | 	client.ReleaseName = ch2art | ||||||
|  |  | ||||||
|  | 	res, err := engine.Render(chartObj, nil) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	logrus.Infof("%v", res) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func getChartPathFromDir(downloadDir string) (file string, err error) { | ||||||
|  | 	files, err := os.ReadDir(downloadDir) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return "", err | 		return "", err | ||||||
| 	} else if len(files) == 0 { | 	} else if len(files) == 0 { | ||||||
| 		return "", fmt.Errorf("expected to have one file, got zero in a dir %s", dir) | 		return "", fmt.Errorf("expected to have one file, got zero in a dir %s", downloadDir) | ||||||
| 	} else if len(files) > 1 { | 	} else if len(files) > 1 { | ||||||
| 		return "", fmt.Errorf("expected to have only one file in a  dir %s", dir) | 		return "", fmt.Errorf("expected to have only one file in a dir %s", downloadDir) | ||||||
| 	} | 	} | ||||||
| 	return files[0].Name(), nil | 	return files[0].Name(), nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,8 +1,13 @@ | |||||||
| package helmhelper | package helmhelper | ||||||
|  |  | ||||||
| import "git.badhouseplants.net/allanger/shoebill/pkg/repository" | import ( | ||||||
|  | 	"git.badhouseplants.net/allanger/shoebill/pkg/repository" | ||||||
|  | ) | ||||||
|  |  | ||||||
| const MOCK_LATEST_VERSION = "v1.12.1" | const ( | ||||||
|  | 	MOCK_LATEST_VERSION = "v1.12.1" | ||||||
|  | 	MOCK_CHART_PATH     = ".charts/repo-release-latest/release-latest.gz" | ||||||
|  | ) | ||||||
|  |  | ||||||
| type Mock struct{} | type Mock struct{} | ||||||
|  |  | ||||||
| @@ -13,3 +18,11 @@ func NewHelmMock() Helmhelper { | |||||||
| func (h *Mock) FindLatestVersion(dir, chart string, repository repository.Repository) (version string, err error) { | func (h *Mock) FindLatestVersion(dir, chart string, repository repository.Repository) (version string, err error) { | ||||||
| 	return MOCK_LATEST_VERSION, nil | 	return MOCK_LATEST_VERSION, nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (h *Mock) PullChart(workdirPath string, repository repository.Repository, chart, version string) (path string, err error) { | ||||||
|  | 	return MOCK_CHART_PATH, nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (h *Mock) RenderChart(workdirPath string, repository repository.Repository, ch2art, version string) error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|   | |||||||
| @@ -4,4 +4,6 @@ import "git.badhouseplants.net/allanger/shoebill/pkg/repository" | |||||||
|  |  | ||||||
| type Helmhelper interface { | type Helmhelper interface { | ||||||
| 	FindLatestVersion(dir, chart string, repository repository.Repository) (string, error) | 	FindLatestVersion(dir, chart string, repository repository.Repository) (string, error) | ||||||
|  | 	PullChart(workdirPath string, repository repository.Repository, chart, version string) (string, error) | ||||||
|  | 	RenderChart(workdirPath string, repository repository.Repository, ch2art, version string) error | ||||||
| } | } | ||||||
|   | |||||||
| @@ -73,6 +73,9 @@ const ( | |||||||
|  |  | ||||||
| // Replace the version placeholder with the fixed version | // Replace the version placeholder with the fixed version | ||||||
| func (r *Release) VersionHandler(dir string, hh helmhelper.Helmhelper) error { | func (r *Release) VersionHandler(dir string, hh helmhelper.Helmhelper) error { | ||||||
|  | 	if len(r.Version) == 0 { | ||||||
|  | 		r.Version = VERSION_LATEST | ||||||
|  | 	} | ||||||
| 	switch r.Version { | 	switch r.Version { | ||||||
| 	case VERSION_LATEST: | 	case VERSION_LATEST: | ||||||
| 		version, err := hh.FindLatestVersion(dir, r.Chart, *r.RepositoryObj) | 		version, err := hh.FindLatestVersion(dir, r.Chart, *r.RepositoryObj) | ||||||
|   | |||||||
| @@ -64,6 +64,7 @@ releases: | |||||||
|  |  | ||||||
|   - name: istiod |   - name: istiod | ||||||
|     repository: istio |     repository: istio | ||||||
|  |     version: latest | ||||||
|     chart: istiod |     chart: istiod | ||||||
|     installed: true |     installed: true | ||||||
|     namespace: istio-system |     namespace: istio-system | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Nikolai Rodionov
					Nikolai Rodionov