func (a *Allocator) doNodeAlloc(ctx context.Context, ev events.Event) { var ( isDelete bool node *api.Node ) switch v := ev.(type) { case state.EventCreateNode: node = v.Node.Copy() case state.EventUpdateNode: node = v.Node.Copy() case state.EventDeleteNode: isDelete = true node = v.Node.Copy() } nc := a.netCtx if isDelete { if nc.nwkAllocator.IsNodeAllocated(node) { if err := nc.nwkAllocator.DeallocateNode(node); err != nil { log.G(ctx).WithError(err).Errorf("Failed freeing network resources for node %s", node.ID) } } return } if !nc.nwkAllocator.IsNodeAllocated(node) { if node.Attachment == nil { node.Attachment = &api.NetworkAttachment{} } node.Attachment.Network = nc.ingressNetwork.Copy() if err := a.allocateNode(ctx, node); err != nil { log.G(ctx).WithError(err).Errorf("Failed to allocate network resources for node %s", node.ID) return } if _, err := a.store.Batch(func(batch *store.Batch) error { return a.commitAllocatedNode(ctx, batch, node) }); err != nil { log.G(ctx).WithError(err).Errorf("Failed to commit allocation of network resources for node %s", node.ID) } } }
func (a *Allocator) doNodeAlloc(ctx context.Context, nc *networkContext, ev events.Event) { var ( isDelete bool node *api.Node ) switch v := ev.(type) { case state.EventCreateNode: node = v.Node.Copy() case state.EventUpdateNode: node = v.Node.Copy() case state.EventDeleteNode: isDelete = true node = v.Node.Copy() } if isDelete { if nc.nwkAllocator.IsNodeAllocated(node) { if err := nc.nwkAllocator.DeallocateNode(node); err != nil { log.G(ctx).Errorf("Failed freeing network resources for node %s: %v", node.ID, err) } } return } if !nc.nwkAllocator.IsNodeAllocated(node) { if node.Attachment == nil { node.Attachment = &api.NetworkAttachment{} } node.Attachment.Network = nc.ingressNetwork.Copy() if err := a.allocateNode(ctx, nc, node); err != nil { log.G(ctx).Errorf("Failed to allocate network resources for node %s: %v", node.ID, err) } } }