package org.opennaas.extensions.roadm.capability.connections;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.opennaas.core.resources.ActivatorException;
import org.opennaas.core.resources.action.IAction;
import org.opennaas.core.resources.action.IActionSet;
import org.opennaas.core.resources.capability.AbstractCapability;
import org.opennaas.core.resources.capability.CapabilityException;
import org.opennaas.core.resources.descriptor.CapabilityDescriptor;
import org.opennaas.core.resources.descriptor.ResourceDescriptorConstants;
import org.opennaas.extensions.queuemanager.IQueueManagerCapability;
import org.opennaas.extensions.router.model.opticalSwitch.FiberConnection;
public class ConnectionsCapability extends AbstractCapability implements IConnectionsCapability {
public static final String CAPABILITY_TYPE = "connections";
public static String CONNECTIONS = CAPABILITY_TYPE;
Log log = LogFactory.getLog(ConnectionsCapability.class);
private String resourceId = "";
public ConnectionsCapability(CapabilityDescriptor descriptor, String resourceId) {
super(descriptor);
this.resourceId = resourceId;
log.debug("Built new Connections Capability");
}
/*
* (non-Javadoc)
*
* @see org.opennaas.core.resources.capability.AbstractCapability#activate()
*/
@Override
public void activate() throws CapabilityException {
registerService(Activator.getContext(), CAPABILITY_TYPE, getResourceType(), getResourceName(), IConnectionsCapability.class.getName());
super.activate();
}
/*
* (non-Javadoc)
*
* @see org.opennaas.core.resources.capability.AbstractCapability#deactivate()
*/
@Override
public void deactivate() throws CapabilityException {
registration.unregister();
super.deactivate();
}
/*
* (non-Javadoc)
*
* @see org.opennaas.core.resources.capability.ICapability#getCapabilityName()
*/
@Override
public String getCapabilityName() {
return CAPABILITY_TYPE;
}
/*
* (non-Javadoc)
*
* @see org.opennaas.core.resources.capability.AbstractCapability#queueAction(org.opennaas.core.resources.action.IAction)
*/
@Override
public void queueAction(IAction action) throws CapabilityException {
getQueueManager(resourceId).queueAction(action);
}
/**
*
* @return QueuemanagerService this capability is associated to.
* @throws CapabilityException
* if desired queueManagerService could not be retrieved.
*/
private IQueueManagerCapability getQueueManager(String resourceId) throws CapabilityException {
try {
return Activator.getQueueManagerService(resourceId);
} catch (ActivatorException e) {
throw new CapabilityException("Failed to get QueueManagerService for resource " + resourceId, e);
}
}
/*
* (non-Javadoc)
*
* @see org.opennaas.core.resources.capability.AbstractCapability#getActionSet()
*/
@Override
public IActionSet getActionSet() throws CapabilityException {
String name = this.descriptor.getPropertyValue(ResourceDescriptorConstants.ACTION_NAME);
String version = this.descriptor.getPropertyValue(ResourceDescriptorConstants.ACTION_VERSION);
try {
return Activator.getConnectionsActionSetService(name, version);
} catch (ActivatorException e) {
throw new CapabilityException(e);
}
}
// IConnectionsCapability implementation
/*
* (non-Javadoc)
*
* @see
* org.opennaas.extensions.roadm.capability.connections.IConnectionsCapability#makeConnection(org.opennaas.extensions.router.model.opticalSwitch
* .FiberConnection)
*/
@Override
public void makeConnection(FiberConnection connectionRequest)
throws CapabilityException {
log.info("Start of makeConnection call");
IAction action = createActionAndCheckParams(ConnectionsActionSet.MAKE_CONNECTION, connectionRequest);
queueAction(action);
log.info("End of makeConnection call");
}
/*
* (non-Javadoc)
*
* @see
* org.opennaas.extensions.roadm.capability.connections.IConnectionsCapability#removeConnection(org.opennaas.extensions.router.model.opticalSwitch
* .FiberConnection)
*/
@Override
public void removeConnection(FiberConnection connectionRequest)
throws CapabilityException {
log.info("Start of removeConnection call");
IAction action = createActionAndCheckParams(ConnectionsActionSet.REMOVE_CONNECTION, connectionRequest);
queueAction(action);
log.info("End of removeConnection call");
}
}