mirror of
https://github.com/kubevirt/containerized-data-importer.git
synced 2025-06-03 06:30:22 +00:00

The io/ioutil package has been deprecated as of Go 1.16 [1]. This commit replaces the existing io/ioutil functions with their new definitions in io and os packages. [1]: https://golang.org/doc/go1.16#ioutil Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
85 lines
2.2 KiB
Go
85 lines
2.2 KiB
Go
package utils
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
"path"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
v1 "k8s.io/api/core/v1"
|
|
k8serrors "k8s.io/apimachinery/pkg/api/errors"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"k8s.io/client-go/kubernetes"
|
|
"k8s.io/client-go/rest"
|
|
certutil "k8s.io/client-go/util/cert"
|
|
"k8s.io/klog/v2"
|
|
)
|
|
|
|
// CreateCertForTestService creates a TLS key/cert for a service, writes them to files
|
|
// and creates a config map containing the cert
|
|
func CreateCertForTestService(namespace, serviceName, configMapName, certDir, certFileName, keyFileName string) error {
|
|
klog.Info("Creating key/certificate")
|
|
|
|
config, err := rest.InClusterConfig()
|
|
if err != nil {
|
|
return errors.Wrap(err, "Error creating rest config")
|
|
}
|
|
|
|
clientset, err := kubernetes.NewForConfig(config)
|
|
if err != nil {
|
|
return errors.Wrap(err, "Error creating kubernetes client")
|
|
}
|
|
|
|
if err := os.MkdirAll(certDir, 0777); err != nil {
|
|
return errors.Wrapf(err, "Error making %s", certDir)
|
|
}
|
|
|
|
namespacedName := serviceName + "." + namespace
|
|
|
|
certBytes, keyBytes, err := certutil.GenerateSelfSignedCertKey(serviceName, nil, []string{namespacedName, namespacedName + ".svc"})
|
|
if err != nil {
|
|
return errors.Wrap(err, "Error generating key/cert")
|
|
}
|
|
|
|
cm := &v1.ConfigMap{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: configMapName,
|
|
},
|
|
Data: map[string]string{
|
|
certFileName: string(certBytes),
|
|
},
|
|
}
|
|
|
|
stored, err := clientset.CoreV1().ConfigMaps(namespace).Get(context.TODO(), configMapName, metav1.GetOptions{})
|
|
if err != nil {
|
|
if !k8serrors.IsNotFound(err) {
|
|
return errors.Wrapf(err, "Error getting configmap %s", configMapName)
|
|
}
|
|
|
|
_, err := clientset.CoreV1().ConfigMaps(namespace).Create(context.TODO(), cm, metav1.CreateOptions{})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
} else {
|
|
cpy := stored.DeepCopy()
|
|
cpy.Data = cm.Data
|
|
_, err := clientset.CoreV1().ConfigMaps(namespace).Update(context.TODO(), cpy, metav1.UpdateOptions{})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
if err = os.WriteFile(path.Join(certDir, certFileName), certBytes, 0644); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err = os.WriteFile(path.Join(certDir, keyFileName), keyBytes, 0600); err != nil {
|
|
return err
|
|
}
|
|
|
|
klog.Info("Successfully created key/certificate")
|
|
return nil
|
|
}
|