/* * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.groupbasedpolicy.renderer.ofoverlay.flow; import org.opendaylight.groupbasedpolicy.renderer.ofoverlay.OfContext; import org.opendaylight.groupbasedpolicy.renderer.ofoverlay.OfWriter; import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.endpoint.rev140421.endpoints.Endpoint; import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * Manage the state of a openflow table by reacting to any events and updating * the table state. This is an abstract class that must be extended for * each specific table being managed. * @author readams */ public abstract class OfTable { protected static final Logger LOG = LoggerFactory.getLogger(OfTable.class); protected final OfContext ctx; public OfTable(OfContext ctx) { this.ctx = ctx; } /** * Update the relevant flow table for the node * * @param endpoint flows will be created for * @param ofWriter the {@link OfWriter} * @throws Exception throws all exception */ public abstract void sync(Endpoint endpoint, OfWriter ofWriter) throws Exception; }