diff --git a/baremetal/metal3datatemplate_manager.go b/baremetal/metal3datatemplate_manager.go index 3e98ca35b9..243e24fd46 100644 --- a/baremetal/metal3datatemplate_manager.go +++ b/baremetal/metal3datatemplate_manager.go @@ -18,7 +18,6 @@ package baremetal import ( "context" - "fmt" "strconv" "github.com/go-logr/logr" @@ -232,6 +231,14 @@ func (m *DataTemplateManager) updateData(ctx context.Context, return indexes, err } } else { + // Check if this claim is in use. Does it have any owners? + // If it is no longer in use, proceed to delete the associated data + if len(dataClaim.OwnerReferences) > 0 { + m.Log.Info("Metal3DataClaim is still in use (has owners). Cannot delete Metal3Data.", + "Metal3DataClaim", dataClaim.Name, "Owners", dataClaim.OwnerReferences) + return indexes, nil + } + indexes, err = m.deleteData(ctx, dataClaim, indexes) if err != nil { return indexes, err @@ -305,17 +312,18 @@ func (m *DataTemplateManager) createData(ctx context.Context, } m.Log.Info("Index", "Claim", dataClaim.Name, "index", claimIndex) - // Create the Metal3Data object, with an Owner ref to the Metal3Machine - // (curOwnerRef) and to the Metal3DataTemplate + // Create the Metal3Data object, with an Owner ref to the dataClaim, + // the dataTemplate, and the dataClaims owners. Also add a finalizer. dataObject := &infrav1.Metal3Data{ TypeMeta: metav1.TypeMeta{ Kind: "Metal3Data", APIVersion: infrav1.GroupVersion.String(), }, ObjectMeta: metav1.ObjectMeta{ - Name: dataName, - Namespace: m.DataTemplate.Namespace, - Labels: dataClaim.Labels, + Name: dataName, + Namespace: m.DataTemplate.Namespace, + Finalizers: []string{infrav1.MachineFinalizer}, + Labels: dataClaim.Labels, OwnerReferences: []metav1.OwnerReference{ { Controller: ptr.To(true), @@ -374,18 +382,18 @@ func (m *DataTemplateManager) createData(ctx context.Context, return indexes, nil } -// DeleteDatas deletes old secrets. +// deleteData removes the finalizers from the DataClaim and deletes the associated Metal3Data. func (m *DataTemplateManager) deleteData(ctx context.Context, dataClaim *infrav1.Metal3DataClaim, indexes map[int]string, ) (map[int]string, error) { - var dataName string - m.Log.Info("Deleting Claim", "Metal3DataClaim", dataClaim.Name) + m.Log.Info("Deleting Metal3Data associated with Metal3DataClaim", "Metal3DataClaim", dataClaim.Name) dataClaimIndex, ok := m.DataTemplate.Status.Indexes[dataClaim.Name] if ok { // Try to get the Metal3Data. if it succeeds, delete it tmpM3Data := &infrav1.Metal3Data{} + var dataName string if m.DataTemplate.Spec.TemplateReference != "" { dataName = m.DataTemplate.Spec.TemplateReference + "-" + strconv.Itoa(dataClaimIndex) } else { @@ -401,26 +409,42 @@ func (m *DataTemplateManager) deleteData(ctx context.Context, dataClaim.Status.ErrorMessage = ptr.To("Failed to get associated Metal3Data object") return indexes, err } else if err == nil { - // Delete the secret with metadata - fmt.Println(tmpM3Data.Name) - err = m.client.Delete(ctx, tmpM3Data) + // Remove the finalizer + tmpM3Data.Finalizers = Filter(tmpM3Data.Finalizers, + infrav1.MachineFinalizer, + ) + err = updateObject(ctx, m.client, tmpM3Data) + if err != nil && !apierrors.IsNotFound(err) { + m.Log.Info("Unable to remove finalizer from Metal3Data", "Metal3Data", tmpM3Data.Name) + return indexes, err + } + // Delete the Metal3Data + err = deleteObject(ctx, m.client, tmpM3Data) if err != nil && !apierrors.IsNotFound(err) { dataClaim.Status.ErrorMessage = ptr.To("Failed to delete associated Metal3Data object") return indexes, err } + m.Log.Info("Deleted Metal3Data", "Metal3Data", tmpM3Data.Name) } } + dataClaim.Status.RenderedData = nil dataClaim.Finalizers = Filter(dataClaim.Finalizers, infrav1.DataClaimFinalizer, ) - m.Log.Info("Deleted Claim", "Metal3DataClaim", dataClaim.Name) + err := updateObject(ctx, m.client, dataClaim) + if err != nil && !apierrors.IsNotFound(err) { + m.Log.Info("Unable to remove finalizers from Metal3DataClaim", "Metal3DataClaim", dataClaim.Name) + return indexes, err + } if ok { delete(m.DataTemplate.Status.Indexes, dataClaim.Name) delete(indexes, dataClaimIndex) } + + // m.Log.Info("Deleted Metal3DataClaim", "Metal3DataClaim", dataClaim.Name) m.updateStatusTimestamp() return indexes, nil }