86 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
| package resources
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"text/template"
 | |
| 
 | |
| 	"github.com/jenkinsci/kubernetes-operator/api/v1alpha2"
 | |
| 	"github.com/jenkinsci/kubernetes-operator/internal/render"
 | |
| 	"github.com/jenkinsci/kubernetes-operator/pkg/constants"
 | |
| 
 | |
| 	corev1 "k8s.io/api/core/v1"
 | |
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | |
| )
 | |
| 
 | |
| const createOperatorUserFileName = "createOperatorUser.groovy"
 | |
| 
 | |
| var createOperatorUserGroovyFmtTemplate = template.Must(template.New(createOperatorUserFileName).Parse(`
 | |
| import hudson.security.*
 | |
| 
 | |
| {{- if .Enable }}
 | |
| def jenkins = jenkins.model.Jenkins.getInstance()
 | |
| def operatorUserCreatedFile = new File('{{ .OperatorUserCreatedFilePath }}')
 | |
| 
 | |
| if (!operatorUserCreatedFile.exists()) {
 | |
| 	def hudsonRealm = new HudsonPrivateSecurityRealm(false)
 | |
| 	hudsonRealm.createAccount(
 | |
| 		new File('{{ .OperatorCredentialsPath }}/{{ .OperatorUserNameFile }}').text,
 | |
| 		new File('{{ .OperatorCredentialsPath }}/{{ .OperatorPasswordFile }}').text)
 | |
| 	jenkins.setSecurityRealm(hudsonRealm)
 | |
| 
 | |
| 	def strategy = new FullControlOnceLoggedInAuthorizationStrategy()
 | |
| 	strategy.setAllowAnonymousRead(false)
 | |
| 	jenkins.setAuthorizationStrategy(strategy)
 | |
| 	jenkins.save()
 | |
| 
 | |
| 	operatorUserCreatedFile.createNewFile()
 | |
| }
 | |
| {{- end }}
 | |
| `))
 | |
| 
 | |
| func buildCreateJenkinsOperatorUserGroovyScript(jenkins *v1alpha2.Jenkins) (*string, error) {
 | |
| 	data := struct {
 | |
| 		Enable                      bool
 | |
| 		OperatorCredentialsPath     string
 | |
| 		OperatorUserNameFile        string
 | |
| 		OperatorPasswordFile        string
 | |
| 		OperatorUserCreatedFilePath string
 | |
| 	}{
 | |
| 		Enable:                      jenkins.Spec.JenkinsAPISettings.AuthorizationStrategy == v1alpha2.CreateUserAuthorizationStrategy,
 | |
| 		OperatorCredentialsPath:     jenkinsOperatorCredentialsVolumePath,
 | |
| 		OperatorUserNameFile:        OperatorCredentialsSecretUserNameKey,
 | |
| 		OperatorPasswordFile:        OperatorCredentialsSecretPasswordKey,
 | |
| 		OperatorUserCreatedFilePath: getJenkinsHomePath(jenkins) + "/operatorUserCreated",
 | |
| 	}
 | |
| 
 | |
| 	output, err := render.Render(createOperatorUserGroovyFmtTemplate, data)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return &output, nil
 | |
| }
 | |
| 
 | |
| // GetInitConfigurationConfigMapName returns name of Kubernetes config map used to init configuration
 | |
| func GetInitConfigurationConfigMapName(jenkins *v1alpha2.Jenkins) string {
 | |
| 	return fmt.Sprintf("%s-init-configuration-%s", constants.OperatorName, jenkins.ObjectMeta.Name)
 | |
| }
 | |
| 
 | |
| // NewInitConfigurationConfigMap builds Kubernetes config map used to init configuration
 | |
| func NewInitConfigurationConfigMap(meta metav1.ObjectMeta, jenkins *v1alpha2.Jenkins) (*corev1.ConfigMap, error) {
 | |
| 	meta.Name = GetInitConfigurationConfigMapName(jenkins)
 | |
| 
 | |
| 	createJenkinsOperatorUserGroovy, err := buildCreateJenkinsOperatorUserGroovyScript(jenkins)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return &corev1.ConfigMap{
 | |
| 		TypeMeta:   buildConfigMapTypeMeta(),
 | |
| 		ObjectMeta: meta,
 | |
| 		Data: map[string]string{
 | |
| 			createOperatorUserFileName: *createJenkinsOperatorUserGroovy,
 | |
| 		},
 | |
| 	}, nil
 | |
| }
 |