mirror of
https://github.com/harvester/vm-import-controller.git
synced 2025-06-03 01:44:51 +00:00

- Import OpenStack server by UUID - Import OpenStack server with upper case characters in its name The following improvements have been done: - Sanitize the configured `VirtualMachineName` field, e.g. convert upper case to lower case to make it RFC 1123 compliant. - Convert UUID to real name for OpenStack imports - Reduce waiting time to recheck if created VM is running from 5min to 2min - Rename variable `uuid` to `serverUUID` in the OpenStack client code to do not collide with the imported uuid module - Improve error and log messages - Fix typos - Add comments Related to: https://github.com/harvester/harvester/issues/6500 Related to: https://github.com/harvester/harvester/issues/6505 Signed-off-by: Volker Theile <vtheile@suse.com>
108 lines
3.5 KiB
Go
108 lines
3.5 KiB
Go
package migration
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
corecontrollers "github.com/rancher/wrangler/pkg/generated/controllers/core/v1"
|
|
"github.com/sirupsen/logrus"
|
|
v1 "k8s.io/api/core/v1"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
|
|
"github.com/harvester/vm-import-controller/pkg/apis/common"
|
|
migration "github.com/harvester/vm-import-controller/pkg/apis/migration.harvesterhci.io/v1beta1"
|
|
migrationController "github.com/harvester/vm-import-controller/pkg/generated/controllers/migration.harvesterhci.io/v1beta1"
|
|
"github.com/harvester/vm-import-controller/pkg/source/openstack"
|
|
"github.com/harvester/vm-import-controller/pkg/util"
|
|
)
|
|
|
|
type openstackHandler struct {
|
|
ctx context.Context
|
|
os migrationController.OpenstackSourceController
|
|
secret corecontrollers.SecretController
|
|
}
|
|
|
|
func RegisterOpenstackController(ctx context.Context, os migrationController.OpenstackSourceController, secret corecontrollers.SecretController) {
|
|
oHandler := &openstackHandler{
|
|
ctx: ctx,
|
|
os: os,
|
|
secret: secret,
|
|
}
|
|
|
|
os.OnChange(ctx, "openstack-migration-change", oHandler.OnSourceChange)
|
|
}
|
|
|
|
func (h *openstackHandler) OnSourceChange(_ string, o *migration.OpenstackSource) (*migration.OpenstackSource, error) {
|
|
if o == nil || o.DeletionTimestamp != nil {
|
|
return o, nil
|
|
}
|
|
|
|
logrus.WithFields(logrus.Fields{
|
|
"kind": o.Kind,
|
|
"name": o.Name,
|
|
"namespace": o.Namespace,
|
|
}).Info("Reconciling source")
|
|
|
|
if o.Status.Status != migration.ClusterReady {
|
|
// process migration logic
|
|
secretObj, err := h.secret.Get(o.Spec.Credentials.Namespace, o.Spec.Credentials.Name, metav1.GetOptions{})
|
|
if err != nil {
|
|
return o, fmt.Errorf("error looking up secret for openstacksource: %v", err)
|
|
}
|
|
|
|
client, err := openstack.NewClient(h.ctx, o.Spec.EndpointAddress, o.Spec.Region, secretObj, o.GetOptions().(migration.OpenstackSourceOptions))
|
|
if err != nil {
|
|
return o, fmt.Errorf("error generating openstack client for openstack migration '%s': %v", o.Name, err)
|
|
}
|
|
|
|
err = client.Verify()
|
|
if err != nil {
|
|
logrus.WithFields(logrus.Fields{
|
|
"apiVersion": o.APIVersion,
|
|
"kind": o.Kind,
|
|
"name": o.Name,
|
|
"namespace": o.Namespace,
|
|
"err": err,
|
|
}).Error("failed to verify client for openstack migration")
|
|
conds := []common.Condition{
|
|
{
|
|
Type: migration.ClusterErrorCondition,
|
|
Status: v1.ConditionTrue,
|
|
LastUpdateTime: metav1.Now().Format(time.RFC3339),
|
|
LastTransitionTime: metav1.Now().Format(time.RFC3339),
|
|
}, {
|
|
Type: migration.ClusterReadyCondition,
|
|
Status: v1.ConditionFalse,
|
|
LastUpdateTime: metav1.Now().Format(time.RFC3339),
|
|
LastTransitionTime: metav1.Now().Format(time.RFC3339),
|
|
},
|
|
}
|
|
|
|
o.Status.Conditions = util.MergeConditions(o.Status.Conditions, conds)
|
|
o.Status.Status = migration.ClusterNotReady
|
|
return h.os.UpdateStatus(o)
|
|
}
|
|
|
|
conds := []common.Condition{
|
|
{
|
|
Type: migration.ClusterReadyCondition,
|
|
Status: v1.ConditionTrue,
|
|
LastUpdateTime: metav1.Now().Format(time.RFC3339),
|
|
LastTransitionTime: metav1.Now().Format(time.RFC3339),
|
|
}, {
|
|
Type: migration.ClusterErrorCondition,
|
|
Status: v1.ConditionFalse,
|
|
LastUpdateTime: metav1.Now().Format(time.RFC3339),
|
|
LastTransitionTime: metav1.Now().Format(time.RFC3339),
|
|
},
|
|
}
|
|
|
|
o.Status.Conditions = util.MergeConditions(o.Status.Conditions, conds)
|
|
o.Status.Status = migration.ClusterReady
|
|
return h.os.UpdateStatus(o)
|
|
|
|
}
|
|
return o, nil
|
|
}
|