2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.protocol.bgp.rib.spi;
10 import javax.annotation.Nonnull;
11 import javax.annotation.Nullable;
12 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev130925.rib.TablesKey;
13 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.AddressFamily;
14 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.SubsequentAddressFamily;
15 import org.opendaylight.yangtools.sal.binding.generator.impl.GeneratedClassLoadingStrategy;
16 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
19 * Interface for acquiring AdjRIBsIn factories. In order for a model-driven RIB implementation to work correctly, it
20 * has to know how to handle individual NLRI fields, whose encoding is specific to a AFI/SAFI pair. This interface
21 * exposes an entry point for locating the AFI/SAFI-specific implementation handler.
23 public interface RIBExtensionConsumerContext {
25 * Acquire a RIB implementation factory for a AFI/SAFI combination.
26 * @param afi Address Family Identifier
27 * @param safi Subsequent Address Family identifier
28 * @return RIB implementation factory, or null if the AFI/SAFI is
31 @Nullable AdjRIBsFactory getAdjRIBsInFactory(@Nonnull Class<? extends AddressFamily> afi, @Nonnull Class<? extends SubsequentAddressFamily> safi);
34 * Acquire a RIB implementation factory for a AFI/SAFI combination.
35 * @param key AFI/SAFI key
36 * @return RIBSupport instance, or null if the AFI/SAFI is
39 @Nullable RIBSupport getRIBSupport(@Nonnull TablesKey key);
42 * Acquire a RIB implementation factory for a AFI/SAFI combination.
43 * @param afi Address Family Identifier
44 * @param safi Subsequent Address Family identifier
45 * @return RIBSupport instance, or null if the AFI/SAFI is
48 @Nullable RIBSupport getRIBSupport(@Nonnull Class<? extends AddressFamily> afi, @Nonnull Class<? extends SubsequentAddressFamily> safi);
51 * Acquire a RIB implementation factory for a AFI/SAFI combination.
52 * @param key Tables key with AFI/SAFI
53 * @return RIBSupport instance, or null if the AFI/SAFI is
56 @Nullable RIBSupport getRIBSupport(YangInstanceIdentifier.NodeIdentifierWithPredicates key);
60 * Returns class loading strategy for loading YANG modeled classes
61 * associated with registered RIB supports.
63 * @return Class loading strategy for loading YANG modeled classes.
65 @Nonnull GeneratedClassLoadingStrategy getClassLoadingStrategy();