blob: ed6f0f781078fcb906a607f66a8c6f1bbf2d5ad2 [file] [log] [blame]
Pavlin Radoslavov5ab68512013-02-18 09:59:33 -08001package net.floodlightcontroller.flowcache.web;
2
3import net.floodlightcontroller.flowcache.IFlowService;
Pavlin Radoslavova10a9a82013-02-22 11:47:54 -08004import net.floodlightcontroller.util.FlowId;
Pavlin Radoslavov5ab68512013-02-18 09:59:33 -08005
6import org.openflow.util.HexString;
7import org.restlet.resource.Get;
8import org.restlet.resource.ServerResource;
9import org.slf4j.Logger;
10import org.slf4j.LoggerFactory;
11
12public class DeleteFlowResource extends ServerResource {
13 protected static Logger log = LoggerFactory.getLogger(DeleteFlowResource.class);
14
15 @Get("json")
16 public Boolean retrieve() {
17 Boolean result = false;
18
19 IFlowService flowService =
20 (IFlowService)getContext().getAttributes().
21 get(IFlowService.class.getCanonicalName());
22
23 if (flowService == null) {
24 log.debug("ONOS Flow Service not found");
25 return result;
26 }
27
28 // Extract the arguments
29 String flowIdStr = (String) getRequestAttributes().get("flow-id");
Pavlin Radoslavov5ab68512013-02-18 09:59:33 -080030
Pavlin Radoslavov2013cbb2013-02-26 10:15:18 -080031 // Process the request
Pavlin Radoslavovbaea9242013-05-08 00:20:09 +000032 if (flowIdStr.equals("all")) {
33 log.debug("Delete All Flows");
34 result = flowService.deleteAllFlows();
35 } else {
36 FlowId flowId = new FlowId(flowIdStr);
37 log.debug("Delete Flow Id: " + flowIdStr);
38 result = flowService.deleteFlow(flowId);
39 }
Pavlin Radoslavov2013cbb2013-02-26 10:15:18 -080040 return result;
Pavlin Radoslavov5ab68512013-02-18 09:59:33 -080041 }
42}