@ -26,6 +26,8 @@ import (
"time"
"github.com/spf13/cobra"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"github.com/fluxcd/pkg/git"
)
@ -41,14 +43,17 @@ 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 = < my - token >
# Run bootstrap for a private repo owned by a GitLab group
# Run bootstrap for a private repo using HTTPS token authentication
gotk bootstrap gitlab -- owner = < group > -- repository = < repo name >
# Run bootstrap for a private repo using SSH authentication
gotk bootstrap gitlab -- owner = < group > -- repository = < repo name > -- ssh - hostname = gitlab . com
# Run bootstrap for a repository path
gotk bootstrap gitlab -- owner = < group > -- repository = < repo name > -- path = dev - cluster
# Run bootstrap for a public repository on a personal account
gotk bootstrap gitlab -- owner = < user > -- repository = < repo name > -- private = false -- personal = true
gotk bootstrap gitlab -- owner = < user > -- repository = < repo name > -- private = false -- personal = true
# Run bootstrap for a private repo hosted on a GitLab server
gotk bootstrap gitlab -- owner = < group > -- repository = < repo name > -- hostname = < domain >
@ -77,7 +82,7 @@ func init() {
bootstrapGitLabCmd . Flags ( ) . BoolVar ( & glPrivate , "private" , true , "is private repository" )
bootstrapGitLabCmd . Flags ( ) . DurationVar ( & glInterval , "interval" , time . Minute , "sync interval" )
bootstrapGitLabCmd . Flags ( ) . StringVar ( & glHostname , "hostname" , git . GitLabDefaultHostname , "GitLab hostname" )
bootstrapGitLabCmd . Flags ( ) . StringVar ( & glSSHHostname , "ssh-hostname" , "" , "GitLab SSH hostname, defaults to hostname if not specified ")
bootstrapGitLabCmd . Flags ( ) . StringVar ( & glSSHHostname , "ssh-hostname" , "" , "GitLab SSH hostname, when specified a deploy key will be added to the repository ")
bootstrapGitLabCmd . Flags ( ) . StringVar ( & glPath , "path" , "" , "repository path, when specified the cluster sync will be scoped to this path" )
bootstrapCmd . AddCommand ( bootstrapGitLabCmd )
@ -172,34 +177,54 @@ func bootstrapGitLabCmdRun(cmd *cobra.Command, args []string) error {
logger . Successf ( "install completed" )
}
// setup SSH deploy key
if shouldCreateDeployKey ( ctx , kubeClient , namespace ) {
logger . Actionf ( "configuring deploy key" )
u , err := url . Parse ( repository . GetSSH ( ) )
if err != nil {
return fmt . Errorf ( "git URL parse failed: %w" , err )
}
repoURL := repository . GetURL ( )
key , err := generateDeployKey ( ctx , kubeClient , u , namespace )
if err != nil {
return fmt . Errorf ( "generating deploy key failed: %w" , err )
if glSSHHostname != "" {
// setup SSH deploy key
repoURL = repository . GetSSH ( )
if shouldCreateDeployKey ( ctx , kubeClient , namespace ) {
logger . Actionf ( "configuring deploy key" )
u , err := url . Parse ( repoURL )
if err != nil {
return fmt . Errorf ( "git URL parse failed: %w" , err )
}
key , err := generateDeployKey ( ctx , kubeClient , u , namespace )
if err != nil {
return fmt . Errorf ( "generating deploy key failed: %w" , err )
}
keyName := "gotk"
if glPath != "" {
keyName = fmt . Sprintf ( "gotk-%s" , glPath )
}
if changed , err := provider . AddDeployKey ( ctx , repository , key , keyName ) ; err != nil {
return err
} else if changed {
logger . Successf ( "deploy key configured" )
}
}
keyName := "gotk"
if glPath != "" {
keyName = fmt . Sprintf ( "gotk-%s" , glPath )
} else {
// setup HTTPS token auth
secret := corev1 . Secret {
ObjectMeta : metav1 . ObjectMeta {
Name : namespace ,
Namespace : namespace ,
} ,
StringData : map [ string ] string {
"username" : "git" ,
"password" : glToken ,
} ,
}
if changed , err := provider . AddDeployKey ( ctx , repository , key , keyName ) ; err != nil {
if err := upsertSecret ( ctx , kubeClient , secret ) ; err != nil {
return err
} else if changed {
logger . Successf ( "deploy key configured" )
}
}
// configure repo synchronization
logger . Actionf ( "generating sync manifests" )
if err := generateSyncManifests ( repository . GetSSH ( ) , bootstrapBranch , namespace , namespace , glPath , tmpDir , glInterval ) ; err != nil {
if err := generateSyncManifests ( repo URL , bootstrapBranch , namespace , namespace , glPath , tmpDir , glInterval ) ; err != nil {
return err
}