Class MappingService
- java.lang.Object
-
- org.opendaylight.lispflowmapping.implementation.MappingService
-
- All Implemented Interfaces:
java.lang.AutoCloseable
,IMappingService
,OdlMappingserviceService
,org.opendaylight.yangtools.yang.binding.RpcService
public class MappingService extends java.lang.Object implements OdlMappingserviceService, IMappingService, java.lang.AutoCloseable
Dispatcher of API calls that implements the RPC and Java APIs in mappingservice.yang and IMappingService respectively. It also coordinates and acts as container for all objects in charge of - saving and updating md-sal datastore stored mappings - monitoring md-sal datastore mapping updates and pushing them to the in memory mapping-system - in memory mapping-system- Author:
- Lorand Jakab, Florin Coras
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.opendaylight.lispflowmapping.interfaces.mappingservice.IMappingService
IMappingService.LookupPolicy
-
-
Constructor Summary
Constructors Constructor Description MappingService(org.opendaylight.mdsal.binding.api.DataBroker broker, org.opendaylight.mdsal.binding.api.NotificationPublishService notificationPublishService, ILispDAO lispDAO)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
addAuthenticationKey(Eid key, MappingAuthkey authKey)
Add authentication key.void
addData(MappingOrigin origin, Eid key, java.lang.String subKey, java.lang.Object data)
Generic addition of data.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddKeyOutput>>
addKey(AddKeyInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddKeysOutput>>
addKeys(AddKeysInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddMappingOutput>>
addMapping(AddMappingInput input)
void
addMapping(MappingOrigin origin, Eid key, SiteId siteId, MappingData mappingData)
Add mapping.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddMappingsOutput>>
addMappings(AddMappingsInput input)
MappingData
addNegativeMapping(Eid key)
Generate and add a negative mapping entry originated from the southbound, and return the generated mapping.void
cleanCachedMappings()
Cleans all cached mappings.Used for testing.void
close()
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetAllKeysOutput>>
getAllKeys(GetAllKeysInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetAllMappingsOutput>>
getAllMappings(GetAllMappingsInput input)
MappingAuthkey
getAuthenticationKey(Eid key)
Retrieve authentication key.java.lang.Object
getData(MappingOrigin origin, Eid key, java.lang.String subKey)
Generic retrieval of data.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetKeyOutput>>
getKey(GetKeyInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetKeysOutput>>
getKeys(GetKeysInput input)
MappingData
getMapping(Eid key)
Retrieves mapping for given key.The lookup policy for the key is defined in the Mapping System.MappingData
getMapping(Eid srcKey, Eid dstKey)
Retrieves mapping with a Source/Dest policy.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetMappingOutput>>
getMapping(GetMappingInput input)
MappingData
getMapping(MappingOrigin origin, Eid key)
Retrieves mapping with given origin for the provided key.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetMappingsOutput>>
getMappings(GetMappingsInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetMappingWithXtrIdOutput>>
getMappingWithXtrId(GetMappingWithXtrIdInput input)
Eid
getParentPrefix(Eid key)
Returns the parent prefix for given key.java.util.Set<Subscriber>
getSubscribers(Eid eid)
Retrieves the subscribers for an EID.java.util.Set<Eid>
getSubtree(MappingOrigin origin, Eid key)
Retrieves the subtree of a maskable prefix from the given map-cache.Eid
getWidestNegativePrefix(Eid key)
Retrieves widest negative prefix found in the Mapping System for given key.void
initialize()
boolean
isMaster()
Get cluster master status.java.lang.String
prettyPrintKeys()
Print keys in cache in a human friendly format.java.lang.String
prettyPrintMappings()
Print mappings in cache in a human friendly format.java.lang.String
printKeys()
Print all authentication keys.java.lang.String
printMappings()
Print all mappings.void
refreshMappingRegistration(Eid key, XtrId xtrId, java.lang.Long timestamp)
Refresh southbound mapping registration timestamp.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveAllKeysOutput>>
removeAllKeys(RemoveAllKeysInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveAllMappingsOutput>>
removeAllMappings(RemoveAllMappingsInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveAllOperationalContentOutput>>
removeAllOperationalContent(RemoveAllOperationalContentInput input)
void
removeAuthenticationKey(Eid key)
Remove authentication key.void
removeData(MappingOrigin origin, Eid key, java.lang.String subKey)
Generic removal of data.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveKeyOutput>>
removeKey(RemoveKeyInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveKeysOutput>>
removeKeys(RemoveKeysInput input)
void
removeMapping(MappingOrigin origin, Eid key)
Remove mapping.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveMappingOutput>>
removeMapping(RemoveMappingInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveMappingsOutput>>
removeMappings(RemoveMappingsInput input)
void
setIsMaster(boolean isMaster)
Set cluster master status.void
setLookupPolicy(IMappingService.LookupPolicy policy)
Configures Mapping Service mapping lookup policy option.void
setMappingMerge(boolean mergeMapping)
Configures Mapping Service mapping merge option.void
subscribe(Subscriber subscriber, Eid subscribedEid)
Subscribe a Subscriber to receive updates about mapping changes for an EID.com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateKeyOutput>>
updateKey(UpdateKeyInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateKeysOutput>>
updateKeys(UpdateKeysInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateMappingOutput>>
updateMapping(UpdateMappingInput input)
com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateMappingsOutput>>
updateMappings(UpdateMappingsInput input)
-
-
-
Constructor Detail
-
MappingService
public MappingService(org.opendaylight.mdsal.binding.api.DataBroker broker, org.opendaylight.mdsal.binding.api.NotificationPublishService notificationPublishService, ILispDAO lispDAO)
-
-
Method Detail
-
setMappingMerge
public void setMappingMerge(boolean mergeMapping)
Description copied from interface:IMappingService
Configures Mapping Service mapping merge option. If set to false, mappings with the same key are overwritten, otherwise, mappings with the same key but from different xTR-IDs are all stored.- Specified by:
setMappingMerge
in interfaceIMappingService
- Parameters:
mergeMapping
- enables or disables mapping merge
-
setLookupPolicy
public void setLookupPolicy(IMappingService.LookupPolicy policy)
Description copied from interface:IMappingService
Configures Mapping Service mapping lookup policy option.- Specified by:
setLookupPolicy
in interfaceIMappingService
- Parameters:
policy
- the policy to be activated
-
initialize
public void initialize()
-
addKey
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddKeyOutput>> addKey(AddKeyInput input)
- Specified by:
addKey
in interfaceOdlMappingserviceService
-
addMapping
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddMappingOutput>> addMapping(AddMappingInput input)
- Specified by:
addMapping
in interfaceOdlMappingserviceService
-
addMapping
public void addMapping(MappingOrigin origin, Eid key, SiteId siteId, MappingData mappingData)
Description copied from interface:IMappingService
Add mapping.- Specified by:
addMapping
in interfaceIMappingService
- Parameters:
origin
- Table where mapping should be addedkey
- Key of the mappingsiteId
- Site that stores the mappingmappingData
- Mapping to be stored
-
addNegativeMapping
public MappingData addNegativeMapping(Eid key)
Description copied from interface:IMappingService
Generate and add a negative mapping entry originated from the southbound, and return the generated mapping.- Specified by:
addNegativeMapping
in interfaceIMappingService
- Parameters:
key
- Key of the mapping- Returns:
- Returns the generated negative mapping (which is never null).
-
refreshMappingRegistration
public void refreshMappingRegistration(Eid key, XtrId xtrId, java.lang.Long timestamp)
Description copied from interface:IMappingService
Refresh southbound mapping registration timestamp.- Specified by:
refreshMappingRegistration
in interfaceIMappingService
- Parameters:
key
- The EID whose registration must be refreshedxtrId
- xTR-ID of the mapping to be refreshedtimestamp
- New timestamp for the mapping
-
getKey
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetKeyOutput>> getKey(GetKeyInput input)
- Specified by:
getKey
in interfaceOdlMappingserviceService
-
getMapping
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetMappingOutput>> getMapping(GetMappingInput input)
- Specified by:
getMapping
in interfaceOdlMappingserviceService
-
getMapping
public MappingData getMapping(MappingOrigin origin, Eid key)
Description copied from interface:IMappingService
Retrieves mapping with given origin for the provided key. The lookup policy for the key is defined in the Mapping System.- Specified by:
getMapping
in interfaceIMappingService
- Parameters:
origin
- Table where the mapping should be looked up.key
- Key to be looked up- Returns:
- Returns the mapping found in the Mapping System or null if nothing is found.
-
getMapping
public MappingData getMapping(Eid key)
Description copied from interface:IMappingService
Retrieves mapping for given key.The lookup policy for the key is defined in the Mapping System.- Specified by:
getMapping
in interfaceIMappingService
- Parameters:
key
- Key to be looked up- Returns:
- Returns the mapping found in the Mapping System or null if nothing is found.
-
getMapping
public MappingData getMapping(Eid srcKey, Eid dstKey)
Description copied from interface:IMappingService
Retrieves mapping with a Source/Dest policy. This method is meant to avoid the overhead of building LcafSourceDest addresses.- Specified by:
getMapping
in interfaceIMappingService
- Parameters:
srcKey
- Source key being looked updstKey
- Destination key being looked up- Returns:
- Returns the mapping found in the Mapping System or null if nothing is found.
-
subscribe
public void subscribe(Subscriber subscriber, Eid subscribedEid)
Description copied from interface:IMappingService
Subscribe a Subscriber to receive updates about mapping changes for an EID.- Specified by:
subscribe
in interfaceIMappingService
- Parameters:
subscriber
- The Subscriber object with information about the subscribersubscribedEid
- The EID for which the subscriber will receive updates
-
getSubscribers
public java.util.Set<Subscriber> getSubscribers(Eid eid)
Description copied from interface:IMappingService
Retrieves the subscribers for an EID.- Specified by:
getSubscribers
in interfaceIMappingService
- Parameters:
eid
- The EID to be looked up- Returns:
- The set of subscribers for the EID
-
getMappingWithXtrId
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetMappingWithXtrIdOutput>> getMappingWithXtrId(GetMappingWithXtrIdInput input)
- Specified by:
getMappingWithXtrId
in interfaceOdlMappingserviceService
-
removeKey
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveKeyOutput>> removeKey(RemoveKeyInput input)
- Specified by:
removeKey
in interfaceOdlMappingserviceService
-
removeMapping
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveMappingOutput>> removeMapping(RemoveMappingInput input)
- Specified by:
removeMapping
in interfaceOdlMappingserviceService
-
removeMapping
public void removeMapping(MappingOrigin origin, Eid key)
Description copied from interface:IMappingService
Remove mapping.- Specified by:
removeMapping
in interfaceIMappingService
- Parameters:
origin
- Table from where the mapping should be removedkey
- Key to be removed
-
updateKey
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateKeyOutput>> updateKey(UpdateKeyInput input)
- Specified by:
updateKey
in interfaceOdlMappingserviceService
-
updateMapping
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateMappingOutput>> updateMapping(UpdateMappingInput input)
- Specified by:
updateMapping
in interfaceOdlMappingserviceService
-
removeKeys
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveKeysOutput>> removeKeys(RemoveKeysInput input)
- Specified by:
removeKeys
in interfaceOdlMappingserviceService
-
removeMappings
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveMappingsOutput>> removeMappings(RemoveMappingsInput input)
- Specified by:
removeMappings
in interfaceOdlMappingserviceService
-
getKeys
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetKeysOutput>> getKeys(GetKeysInput input)
- Specified by:
getKeys
in interfaceOdlMappingserviceService
-
addMappings
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddMappingsOutput>> addMappings(AddMappingsInput input)
- Specified by:
addMappings
in interfaceOdlMappingserviceService
-
updateKeys
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateKeysOutput>> updateKeys(UpdateKeysInput input)
- Specified by:
updateKeys
in interfaceOdlMappingserviceService
-
removeAllMappings
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveAllMappingsOutput>> removeAllMappings(RemoveAllMappingsInput input)
- Specified by:
removeAllMappings
in interfaceOdlMappingserviceService
-
removeAllKeys
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveAllKeysOutput>> removeAllKeys(RemoveAllKeysInput input)
- Specified by:
removeAllKeys
in interfaceOdlMappingserviceService
-
getAllKeys
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetAllKeysOutput>> getAllKeys(GetAllKeysInput input)
- Specified by:
getAllKeys
in interfaceOdlMappingserviceService
-
updateMappings
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<UpdateMappingsOutput>> updateMappings(UpdateMappingsInput input)
- Specified by:
updateMappings
in interfaceOdlMappingserviceService
-
addKeys
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<AddKeysOutput>> addKeys(AddKeysInput input)
- Specified by:
addKeys
in interfaceOdlMappingserviceService
-
getAllMappings
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetAllMappingsOutput>> getAllMappings(GetAllMappingsInput input)
- Specified by:
getAllMappings
in interfaceOdlMappingserviceService
-
getMappings
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<GetMappingsOutput>> getMappings(GetMappingsInput input)
- Specified by:
getMappings
in interfaceOdlMappingserviceService
-
removeAllOperationalContent
public com.google.common.util.concurrent.ListenableFuture<org.opendaylight.yangtools.yang.common.RpcResult<RemoveAllOperationalContentOutput>> removeAllOperationalContent(RemoveAllOperationalContentInput input)
- Specified by:
removeAllOperationalContent
in interfaceOdlMappingserviceService
-
getWidestNegativePrefix
public Eid getWidestNegativePrefix(Eid key)
Description copied from interface:IMappingService
Retrieves widest negative prefix found in the Mapping System for given key.- Specified by:
getWidestNegativePrefix
in interfaceIMappingService
- Parameters:
key
- Key being looked up- Returns:
- Returns the widest negative prefix or null if nothing is found.
-
getSubtree
public java.util.Set<Eid> getSubtree(MappingOrigin origin, Eid key)
Description copied from interface:IMappingService
Retrieves the subtree of a maskable prefix from the given map-cache.- Specified by:
getSubtree
in interfaceIMappingService
- Parameters:
origin
- Table where the key should be looked upkey
- Key to be looked up- Returns:
- The child prefixes of the prefix, including the prefix itself if present
-
addAuthenticationKey
public void addAuthenticationKey(Eid key, MappingAuthkey authKey)
Description copied from interface:IMappingService
Add authentication key.- Specified by:
addAuthenticationKey
in interfaceIMappingService
- Parameters:
key
- The key for which the authentication key is addedauthKey
- The authentication key
-
getAuthenticationKey
public MappingAuthkey getAuthenticationKey(Eid key)
Description copied from interface:IMappingService
Retrieve authentication key.- Specified by:
getAuthenticationKey
in interfaceIMappingService
- Parameters:
key
- The key for which the authentication key is being looked up.- Returns:
- The authentication key.
-
removeAuthenticationKey
public void removeAuthenticationKey(Eid key)
Description copied from interface:IMappingService
Remove authentication key.- Specified by:
removeAuthenticationKey
in interfaceIMappingService
- Parameters:
key
- Key for which the authentication key should be removed.
-
addData
public void addData(MappingOrigin origin, Eid key, java.lang.String subKey, java.lang.Object data)
Description copied from interface:IMappingService
Generic addition of data. Not stored in MD-SAL datastore!- Specified by:
addData
in interfaceIMappingService
- Parameters:
origin
- Table where data should be insertedkey
- The key where data should be insertedsubKey
- The subKey where data should be inserteddata
- The data to be stored
-
getData
public java.lang.Object getData(MappingOrigin origin, Eid key, java.lang.String subKey)
Description copied from interface:IMappingService
Generic retrieval of data.- Specified by:
getData
in interfaceIMappingService
- Parameters:
origin
- Table from where the data should be readkey
- The key where the data is storedsubKey
- The subKey where data is stored- Returns:
- The data
-
removeData
public void removeData(MappingOrigin origin, Eid key, java.lang.String subKey)
Description copied from interface:IMappingService
Generic removal of data.- Specified by:
removeData
in interfaceIMappingService
- Parameters:
origin
- The table from where the data should be removedkey
- The key of the data to be removedsubKey
- The subKey of the data to be removed
-
getParentPrefix
public Eid getParentPrefix(Eid key)
Description copied from interface:IMappingService
Returns the parent prefix for given key.- Specified by:
getParentPrefix
in interfaceIMappingService
- Parameters:
key
- The key which parent is to be returned.- Returns:
- The parent perfix of a specific key.
-
printMappings
public java.lang.String printMappings()
Description copied from interface:IMappingService
Print all mappings. Used for testing, debugging and the karaf shell.- Specified by:
printMappings
in interfaceIMappingService
- Returns:
- String consisting of all mappings
-
prettyPrintMappings
public java.lang.String prettyPrintMappings()
Description copied from interface:IMappingService
Print mappings in cache in a human friendly format.- Specified by:
prettyPrintMappings
in interfaceIMappingService
- Returns:
- a String consisting of all the mappings in the cache
-
printKeys
public java.lang.String printKeys()
Description copied from interface:IMappingService
Print all authentication keys. Used for testing, debugging and the karaf shell.- Specified by:
printKeys
in interfaceIMappingService
- Returns:
- String consisting of all mappings
-
prettyPrintKeys
public java.lang.String prettyPrintKeys()
Description copied from interface:IMappingService
Print keys in cache in a human friendly format.- Specified by:
prettyPrintKeys
in interfaceIMappingService
- Returns:
- a String consisting of all the keys in the cache
-
close
public void close() throws java.lang.Exception
- Specified by:
close
in interfacejava.lang.AutoCloseable
- Throws:
java.lang.Exception
-
cleanCachedMappings
public void cleanCachedMappings()
Description copied from interface:IMappingService
Cleans all cached mappings.Used for testing.- Specified by:
cleanCachedMappings
in interfaceIMappingService
-
setIsMaster
public void setIsMaster(boolean isMaster)
Description copied from interface:IMappingService
Set cluster master status.- Specified by:
setIsMaster
in interfaceIMappingService
- Parameters:
isMaster
- is|isn't master
-
isMaster
public boolean isMaster()
Description copied from interface:IMappingService
Get cluster master status.- Specified by:
isMaster
in interfaceIMappingService
- Returns:
- isMaster is|isn't master
-
-