From d236a9af5747e4e783138df8edc0595789cd6198 Mon Sep 17 00:00:00 2001 From: Philip Laine Date: Wed, 13 Jan 2021 23:44:24 +0100 Subject: [PATCH] Add git implementation to generate sync options Signed-off-by: Philip Laine --- cmd/flux/bootstrap.go | 15 ++++++++------- cmd/flux/bootstrap_github.go | 2 +- cmd/flux/bootstrap_gitlab.go | 4 ++-- docs/cmd/flux_bootstrap_github.md | 2 +- docs/cmd/flux_bootstrap_gitlab.md | 4 ++-- pkg/manifestgen/sync/options.go | 30 ++++++++++++++++-------------- pkg/manifestgen/sync/sync.go | 1 + 7 files changed, 31 insertions(+), 27 deletions(-) diff --git a/cmd/flux/bootstrap.go b/cmd/flux/bootstrap.go index 0bf38de6..9bccfdd4 100644 --- a/cmd/flux/bootstrap.go +++ b/cmd/flux/bootstrap.go @@ -164,13 +164,14 @@ func applyInstallManifests(ctx context.Context, manifestPath string, components func generateSyncManifests(url, branch, name, namespace, targetPath, tmpDir string, interval time.Duration) (string, error) { opts := sync.Options{ - Name: name, - Namespace: namespace, - URL: url, - Branch: branch, - Interval: interval, - TargetPath: targetPath, - ManifestFile: sync.MakeDefaultOptions().ManifestFile, + Name: name, + Namespace: namespace, + URL: url, + Branch: branch, + Interval: interval, + TargetPath: targetPath, + ManifestFile: sync.MakeDefaultOptions().ManifestFile, + GitImplementation: sync.MakeDefaultOptions().GitImplementation, } manifest, err := sync.Generate(opts) diff --git a/cmd/flux/bootstrap_github.go b/cmd/flux/bootstrap_github.go index a0e808d9..336423de 100644 --- a/cmd/flux/bootstrap_github.go +++ b/cmd/flux/bootstrap_github.go @@ -57,7 +57,7 @@ the bootstrap command will perform an upgrade if needed.`, flux bootstrap github --owner= --repository= --path=dev-cluster # Run bootstrap for a public repository on a personal account - flux bootstrap github --owner= --repository= --private=false --personal=true + flux bootstrap github --owner= --repository= --private=false --personal=true # Run bootstrap for a private repo hosted on GitHub Enterprise using SSH auth flux bootstrap github --owner= --repository= --hostname= --ssh-hostname= diff --git a/cmd/flux/bootstrap_gitlab.go b/cmd/flux/bootstrap_gitlab.go index c2b0b609..dbbc5793 100644 --- a/cmd/flux/bootstrap_gitlab.go +++ b/cmd/flux/bootstrap_gitlab.go @@ -48,7 +48,7 @@ the bootstrap command will perform an upgrade if needed.`, Example: ` # Create a GitLab API token and export it as an env var export GITLAB_TOKEN= - # Run bootstrap for a private repo using HTTPS token authentication + # Run bootstrap for a private repo using HTTPS token authentication flux bootstrap gitlab --owner= --repository= --token-auth # Run bootstrap for a private repo using SSH authentication @@ -60,7 +60,7 @@ the bootstrap command will perform an upgrade if needed.`, # Run bootstrap for a public repository on a personal account flux bootstrap gitlab --owner= --repository= --private=false --personal --token-auth - # Run bootstrap for a private repo hosted on a GitLab server + # Run bootstrap for a private repo hosted on a GitLab server flux bootstrap gitlab --owner= --repository= --hostname= --token-auth # Run bootstrap for a an existing repository with a branch named main diff --git a/docs/cmd/flux_bootstrap_github.md b/docs/cmd/flux_bootstrap_github.md index 2836d346..784579e3 100644 --- a/docs/cmd/flux_bootstrap_github.md +++ b/docs/cmd/flux_bootstrap_github.md @@ -30,7 +30,7 @@ flux bootstrap github [flags] flux bootstrap github --owner= --repository= --path=dev-cluster # Run bootstrap for a public repository on a personal account - flux bootstrap github --owner= --repository= --private=false --personal=true + flux bootstrap github --owner= --repository= --private=false --personal=true # Run bootstrap for a private repo hosted on GitHub Enterprise using SSH auth flux bootstrap github --owner= --repository= --hostname= --ssh-hostname= diff --git a/docs/cmd/flux_bootstrap_gitlab.md b/docs/cmd/flux_bootstrap_gitlab.md index 399c8370..3df2f26e 100644 --- a/docs/cmd/flux_bootstrap_gitlab.md +++ b/docs/cmd/flux_bootstrap_gitlab.md @@ -20,7 +20,7 @@ flux bootstrap gitlab [flags] # Create a GitLab API token and export it as an env var export GITLAB_TOKEN= - # Run bootstrap for a private repo using HTTPS token authentication + # Run bootstrap for a private repo using HTTPS token authentication flux bootstrap gitlab --owner= --repository= --token-auth # Run bootstrap for a private repo using SSH authentication @@ -32,7 +32,7 @@ flux bootstrap gitlab [flags] # Run bootstrap for a public repository on a personal account flux bootstrap gitlab --owner= --repository= --private=false --personal --token-auth - # Run bootstrap for a private repo hosted on a GitLab server + # Run bootstrap for a private repo hosted on a GitLab server flux bootstrap gitlab --owner= --repository= --hostname= --token-auth # Run bootstrap for a an existing repository with a branch named main diff --git a/pkg/manifestgen/sync/options.go b/pkg/manifestgen/sync/options.go index 411612af..93b37acc 100644 --- a/pkg/manifestgen/sync/options.go +++ b/pkg/manifestgen/sync/options.go @@ -19,23 +19,25 @@ package sync import "time" type Options struct { - Interval time.Duration - URL string - Name string - Namespace string - Branch string - TargetPath string - ManifestFile string + Interval time.Duration + URL string + Name string + Namespace string + Branch string + TargetPath string + ManifestFile string + GitImplementation string } func MakeDefaultOptions() Options { return Options{ - Interval: 1 * time.Minute, - URL: "", - Name: "flux-system", - Namespace: "flux-system", - Branch: "main", - ManifestFile: "gotk-sync.yaml", - TargetPath: "", + Interval: 1 * time.Minute, + URL: "", + Name: "flux-system", + Namespace: "flux-system", + Branch: "main", + ManifestFile: "gotk-sync.yaml", + TargetPath: "", + GitImplementation: "go-git", } } diff --git a/pkg/manifestgen/sync/sync.go b/pkg/manifestgen/sync/sync.go index 840d8498..d112f6dd 100644 --- a/pkg/manifestgen/sync/sync.go +++ b/pkg/manifestgen/sync/sync.go @@ -55,6 +55,7 @@ func Generate(options Options) (*manifestgen.Manifest, error) { SecretRef: &corev1.LocalObjectReference{ Name: options.Name, }, + GitImplementation: options.GitImplementation, }, }