mirror of
https://github.com/fluxcd/flux2.git
synced 2025-10-29 07:19:07 +08:00
Put potentially destructive reconcile behind flag
The behavior introduced during the introduction of go-git-providers was more strict, and has proven pretty quickly to not be useful to all users. Therefore, the reconciliation behavior for repository configuration has been put behind an opt-in flag, so that it does not overwrite people their configs by accident. Signed-off-by: Hidde Beydals <hello@hidde.co>
This commit is contained in:
@ -80,6 +80,7 @@ type githubFlags struct {
|
|||||||
path flags.SafeRelativePath
|
path flags.SafeRelativePath
|
||||||
teams []string
|
teams []string
|
||||||
readWriteKey bool
|
readWriteKey bool
|
||||||
|
reconcile bool
|
||||||
}
|
}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -100,6 +101,7 @@ func init() {
|
|||||||
bootstrapGitHubCmd.Flags().StringVar(&githubArgs.hostname, "hostname", ghDefaultDomain, "GitHub hostname")
|
bootstrapGitHubCmd.Flags().StringVar(&githubArgs.hostname, "hostname", ghDefaultDomain, "GitHub hostname")
|
||||||
bootstrapGitHubCmd.Flags().Var(&githubArgs.path, "path", "path relative to the repository root, when specified the cluster sync will be scoped to this path")
|
bootstrapGitHubCmd.Flags().Var(&githubArgs.path, "path", "path relative to the repository root, when specified the cluster sync will be scoped to this path")
|
||||||
bootstrapGitHubCmd.Flags().BoolVar(&githubArgs.readWriteKey, "read-write-key", false, "if true, the deploy key is configured with read/write permissions")
|
bootstrapGitHubCmd.Flags().BoolVar(&githubArgs.readWriteKey, "read-write-key", false, "if true, the deploy key is configured with read/write permissions")
|
||||||
|
bootstrapGitHubCmd.Flags().BoolVar(&githubArgs.reconcile, "reconcile", false, "if true, the configured options are also reconciled if the repository already exists")
|
||||||
|
|
||||||
bootstrapCmd.AddCommand(bootstrapGitHubCmd)
|
bootstrapCmd.AddCommand(bootstrapGitHubCmd)
|
||||||
}
|
}
|
||||||
@ -235,6 +237,9 @@ func bootstrapGitHubCmdRun(cmd *cobra.Command, args []string) error {
|
|||||||
if !githubArgs.private {
|
if !githubArgs.private {
|
||||||
bootstrapOpts = append(bootstrapOpts, bootstrap.WithProviderRepositoryConfig("", "", "public"))
|
bootstrapOpts = append(bootstrapOpts, bootstrap.WithProviderRepositoryConfig("", "", "public"))
|
||||||
}
|
}
|
||||||
|
if githubArgs.reconcile {
|
||||||
|
bootstrapOpts = append(bootstrapOpts, bootstrap.WithReconcile())
|
||||||
|
}
|
||||||
|
|
||||||
// Setup bootstrapper with constructed configs
|
// Setup bootstrapper with constructed configs
|
||||||
b, err := bootstrap.NewGitProviderBootstrapper(gitClient, providerClient, kubeClient, bootstrapOpts...)
|
b, err := bootstrap.NewGitProviderBootstrapper(gitClient, providerClient, kubeClient, bootstrapOpts...)
|
||||||
|
|||||||
@ -86,6 +86,7 @@ type gitlabFlags struct {
|
|||||||
path flags.SafeRelativePath
|
path flags.SafeRelativePath
|
||||||
teams []string
|
teams []string
|
||||||
readWriteKey bool
|
readWriteKey bool
|
||||||
|
reconcile bool
|
||||||
}
|
}
|
||||||
|
|
||||||
var gitlabArgs gitlabFlags
|
var gitlabArgs gitlabFlags
|
||||||
@ -100,6 +101,7 @@ func init() {
|
|||||||
bootstrapGitLabCmd.Flags().StringVar(&gitlabArgs.hostname, "hostname", glDefaultDomain, "GitLab hostname")
|
bootstrapGitLabCmd.Flags().StringVar(&gitlabArgs.hostname, "hostname", glDefaultDomain, "GitLab hostname")
|
||||||
bootstrapGitLabCmd.Flags().Var(&gitlabArgs.path, "path", "path relative to the repository root, when specified the cluster sync will be scoped to this path")
|
bootstrapGitLabCmd.Flags().Var(&gitlabArgs.path, "path", "path relative to the repository root, when specified the cluster sync will be scoped to this path")
|
||||||
bootstrapGitLabCmd.Flags().BoolVar(&gitlabArgs.readWriteKey, "read-write-key", false, "if true, the deploy key is configured with read/write permissions")
|
bootstrapGitLabCmd.Flags().BoolVar(&gitlabArgs.readWriteKey, "read-write-key", false, "if true, the deploy key is configured with read/write permissions")
|
||||||
|
bootstrapGitLabCmd.Flags().BoolVar(&gitlabArgs.reconcile, "reconcile", false, "if true, the configured options are also reconciled if the repository already exists")
|
||||||
|
|
||||||
bootstrapCmd.AddCommand(bootstrapGitLabCmd)
|
bootstrapCmd.AddCommand(bootstrapGitLabCmd)
|
||||||
}
|
}
|
||||||
@ -251,6 +253,9 @@ func bootstrapGitLabCmdRun(cmd *cobra.Command, args []string) error {
|
|||||||
if !gitlabArgs.private {
|
if !gitlabArgs.private {
|
||||||
bootstrapOpts = append(bootstrapOpts, bootstrap.WithProviderRepositoryConfig("", "", "public"))
|
bootstrapOpts = append(bootstrapOpts, bootstrap.WithProviderRepositoryConfig("", "", "public"))
|
||||||
}
|
}
|
||||||
|
if gitlabArgs.reconcile {
|
||||||
|
bootstrapOpts = append(bootstrapOpts, bootstrap.WithReconcile())
|
||||||
|
}
|
||||||
|
|
||||||
// Setup bootstrapper with constructed configs
|
// Setup bootstrapper with constructed configs
|
||||||
b, err := bootstrap.NewGitProviderBootstrapper(gitClient, providerClient, kubeClient, bootstrapOpts...)
|
b, err := bootstrap.NewGitProviderBootstrapper(gitClient, providerClient, kubeClient, bootstrapOpts...)
|
||||||
|
|||||||
@ -56,6 +56,7 @@ flux bootstrap github [flags]
|
|||||||
--personal if true, the owner is assumed to be a GitHub user; otherwise an org
|
--personal if true, the owner is assumed to be a GitHub user; otherwise an org
|
||||||
--private if true, the repository is setup or configured as private (default true)
|
--private if true, the repository is setup or configured as private (default true)
|
||||||
--read-write-key if true, the deploy key is configured with read/write permissions
|
--read-write-key if true, the deploy key is configured with read/write permissions
|
||||||
|
--reconcile if true, the configured options are also reconciled if the repository already exists
|
||||||
--repository string GitHub repository name
|
--repository string GitHub repository name
|
||||||
--team stringArray GitHub team to be given maintainer access
|
--team stringArray GitHub team to be given maintainer access
|
||||||
```
|
```
|
||||||
|
|||||||
@ -53,6 +53,7 @@ flux bootstrap gitlab [flags]
|
|||||||
--personal if true, the owner is assumed to be a GitLab user; otherwise a group
|
--personal if true, the owner is assumed to be a GitLab user; otherwise a group
|
||||||
--private if true, the repository is setup or configured as private (default true)
|
--private if true, the repository is setup or configured as private (default true)
|
||||||
--read-write-key if true, the deploy key is configured with read/write permissions
|
--read-write-key if true, the deploy key is configured with read/write permissions
|
||||||
|
--reconcile if true, the configured options are also reconciled if the repository already exists
|
||||||
--repository string GitLab repository name
|
--repository string GitLab repository name
|
||||||
--team stringArray GitLab teams to be given maintainer access
|
--team stringArray GitLab teams to be given maintainer access
|
||||||
```
|
```
|
||||||
|
|||||||
@ -45,6 +45,8 @@ type GitProviderBootstrapper struct {
|
|||||||
defaultBranch string
|
defaultBranch string
|
||||||
visibility string
|
visibility string
|
||||||
|
|
||||||
|
reconcile bool
|
||||||
|
|
||||||
teams map[string]string
|
teams map[string]string
|
||||||
|
|
||||||
readWriteKey bool
|
readWriteKey bool
|
||||||
@ -168,6 +170,16 @@ func (o sshHostnameOption) applyGitProvider(b *GitProviderBootstrapper) {
|
|||||||
b.sshHostname = string(o)
|
b.sshHostname = string(o)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WithReconcile() GitProviderOption {
|
||||||
|
return reconcileOption(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
type reconcileOption bool
|
||||||
|
|
||||||
|
func (o reconcileOption) applyGitProvider(b *GitProviderBootstrapper) {
|
||||||
|
b.reconcile = true
|
||||||
|
}
|
||||||
|
|
||||||
func (b *GitProviderBootstrapper) ReconcileSyncConfig(ctx context.Context, options sync.Options) error {
|
func (b *GitProviderBootstrapper) ReconcileSyncConfig(ctx context.Context, options sync.Options) error {
|
||||||
repo, err := b.getRepository(ctx)
|
repo, err := b.getRepository(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -279,18 +291,20 @@ func (b *GitProviderBootstrapper) reconcileOrgRepository(ctx context.Context) (g
|
|||||||
b.logger.Successf("repository %q created", repoRef.String())
|
b.logger.Successf("repository %q created", repoRef.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set default branch before calling Reconcile due to bug described
|
|
||||||
// above.
|
|
||||||
repoInfo.DefaultBranch = repo.Get().DefaultBranch
|
|
||||||
var changed bool
|
var changed bool
|
||||||
if err = retry(1, 2*time.Second, func() (err error) {
|
if b.reconcile {
|
||||||
repo, changed, err = b.provider.OrgRepositories().Reconcile(ctx, repoRef, repoInfo)
|
// Set default branch before calling Reconcile due to bug described
|
||||||
return
|
// above.
|
||||||
}); err != nil {
|
repoInfo.DefaultBranch = repo.Get().DefaultBranch
|
||||||
return nil, fmt.Errorf("failed to reconcile Git repository %q: %w", repoRef.String(), err)
|
if err = retry(1, 2*time.Second, func() (err error) {
|
||||||
}
|
repo, changed, err = b.provider.OrgRepositories().Reconcile(ctx, repoRef, repoInfo)
|
||||||
if changed {
|
return
|
||||||
b.logger.Successf("repository %q reconciled", repoRef.String())
|
}); err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to reconcile Git repository %q: %w", repoRef.String(), err)
|
||||||
|
}
|
||||||
|
if changed {
|
||||||
|
b.logger.Successf("repository %q reconciled", repoRef.String())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Build the team access config
|
// Build the team access config
|
||||||
@ -343,27 +357,27 @@ func (b *GitProviderBootstrapper) reconcileUserRepository(ctx context.Context) (
|
|||||||
// of the available Reconcile methods, and setting e.g. the default
|
// of the available Reconcile methods, and setting e.g. the default
|
||||||
// branch correctly. Resort to Create with AutoInit until this has
|
// branch correctly. Resort to Create with AutoInit until this has
|
||||||
// been resolved.
|
// been resolved.
|
||||||
repo, err = b.provider.UserRepositories().Create(ctx, repoRef, repoInfo, &gitprovider.RepositoryCreateOptions{
|
repo, err = b.provider.UserRepositories().Create(ctx, repoRef, repoInfo, &gitprovider.RepositoryCreateOptions{})
|
||||||
AutoInit: gitprovider.BoolVar(true),
|
|
||||||
})
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("failed to create new Git repository %q: %w", repoRef.String(), err)
|
return nil, fmt.Errorf("failed to create new Git repository %q: %w", repoRef.String(), err)
|
||||||
}
|
}
|
||||||
b.logger.Successf("repository %q created", repoRef.String())
|
b.logger.Successf("repository %q created", repoRef.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set default branch before calling Reconcile due to bug described
|
if b.reconcile {
|
||||||
// above.
|
// Set default branch before calling Reconcile due to bug described
|
||||||
repoInfo.DefaultBranch = repo.Get().DefaultBranch
|
// above.
|
||||||
var changed bool
|
repoInfo.DefaultBranch = repo.Get().DefaultBranch
|
||||||
if err = retry(1, 2*time.Second, func() (err error) {
|
var changed bool
|
||||||
repo, changed, err = b.provider.UserRepositories().Reconcile(ctx, repoRef, repoInfo)
|
if err = retry(1, 2*time.Second, func() (err error) {
|
||||||
return
|
repo, changed, err = b.provider.UserRepositories().Reconcile(ctx, repoRef, repoInfo)
|
||||||
}); err != nil {
|
return
|
||||||
return nil, fmt.Errorf("failed to reconcile Git repository %q: %w", repoRef.String(), err)
|
}); err != nil {
|
||||||
}
|
return nil, fmt.Errorf("failed to reconcile Git repository %q: %w", repoRef.String(), err)
|
||||||
if changed {
|
}
|
||||||
b.logger.Successf("repository %q reconciled", repoRef.String())
|
if changed {
|
||||||
|
b.logger.Successf("repository %q reconciled", repoRef.String())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return repo, nil
|
return repo, nil
|
||||||
|
|||||||
Reference in New Issue
Block a user