package org.opennaas.extensions.network.capability.basic; /* * #%L * OpenNaaS :: Network :: Basic capability * %% * Copyright (C) 2007 - 2014 FundaciĆ³ Privada i2CAT, Internet i InnovaciĆ³ a Catalunya * %% * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * #L% */ import javax.ws.rs.Consumes; import javax.ws.rs.POST; import javax.ws.rs.Path; import javax.ws.rs.core.MediaType; import org.opennaas.core.resources.IResource; import org.opennaas.core.resources.capability.CapabilityException; import org.opennaas.core.resources.capability.ICapability; import org.opennaas.extensions.network.model.NetworkModel; import org.opennaas.extensions.network.model.topology.Interface; import org.opennaas.extensions.network.model.topology.Link; import org.opennaas.extensions.network.model.topology.NetworkConnection; @Path("/") public interface INetworkBasicCapability extends ICapability { /** * Adds resource to network topology. * * @param resourceId * the id of the resource * * @return NetworkModel updated with added resource * @throws CapabilityException * if an error occurred. */ @Path("/addResource") @POST @Consumes(MediaType.APPLICATION_XML) public void addResource(String resourceId) throws CapabilityException; /** * Adds resource to network topology. * * @param resourceToAdd * IResource to be added * @return NetworkModel updated with added resource * @throws CapabilityException * if an error occurred. */ public NetworkModel addResource(IResource resourceToAdd) throws CapabilityException; /** * Removes a resource from network topology. * * @param resourceId * the id of the resource * @return NetworkModel updated with added resource * @throws CapabilityException * if an error occurred. */ @Path("/removeResource") @POST @Consumes(MediaType.APPLICATION_XML) public void removeResource(String resourceId) throws CapabilityException; /** * Removes a resource from network topology. * * @param resourceId * the id of the resource * @return NetworkModel updated without resourceToRemove * @throws CapabilityException * if an error occurred. */ public NetworkModel removeResource(IResource resourceToRemove) throws CapabilityException; /** * Creates a L2 connection between given interfaces in network topology. * * This method does not interact with real interfaces, connection is only created in topology, despite having real connectivity or not. * * @param link * @return NetworkConnection linking given interfaces. * @throws CapabilityException * if an error occurred. */ @Path("/l2attach") @POST @Consumes(MediaType.APPLICATION_XML) public void l2attach(Link link) throws CapabilityException; /** * Creates a L2 connection between given interfaces in network topology. * * This method does not interact with real interfaces, connection is only created in topology, despite having real connectivity or not. * * @param interface1 * @param interface2 * @return NetworkConnection linking given interfaces. * @throws CapabilityException * if an error occurred. */ public NetworkConnection l2attach(Interface interface1, Interface interface2) throws CapabilityException; /** * Removes a L2 connection between given interfaces in network topology. * * This method does not interact with real interfaces, connection is only removed from topology, despite having real connectivity or not. * * @param link * @throws CapabilityException * if an error occurred. */ @Path("/l2detach") @POST @Consumes(MediaType.APPLICATION_XML) public void l2detach(Link link) throws CapabilityException; /** * Removes a L2 connection between given interfaces in network topology. * * This method does not interact with real interfaces, connection is only removed from topology, despite having real connectivity or not. * * @param interface1 * @param interface2 * @throws CapabilityException * if an error occurred. */ public void l2detach(Interface interface1, Interface interface2) throws CapabilityException; }