in pkg/virtualnode/enqueue_requests_for_virtualservice_events.go [50:74]
func (h *enqueueRequestsForVirtualServiceEvents) enqueueVirtualNodesForMesh(ctx context.Context, queue workqueue.RateLimitingInterface, meshRef *appmesh.MeshReference, vs *appmesh.VirtualService) {
vnList := &appmesh.VirtualNodeList{}
if err := h.k8sClient.List(ctx, vnList); err != nil {
h.log.Error(err, "failed to enqueue virtualNodes for virtual service events", "mesh", meshRef.Name)
return
}
for _, vn := range vnList.Items {
if vn.Spec.MeshRef == nil || *meshRef != *vn.Spec.MeshRef {
continue
}
for _, bg := range vn.Spec.BackendGroups {
if bg.Name == "*" {
if bg.Namespace != nil {
if *bg.Namespace == vs.Namespace {
queue.Add(ctrl.Request{NamespacedName: k8s.NamespacedName(&vn)})
}
} else {
if vs.Namespace == vn.Namespace {
queue.Add(ctrl.Request{NamespacedName: k8s.NamespacedName(&vn)})
}
}
}
}
}
}