blob: fb3d1000a1c0d63ecea5419f404f76eb626c7f71 [file] [log] [blame]
HIGUCHI Yutaefa54882013-06-12 13:13:02 -07001package net.onrc.onos.ofcontroller.flowcache.web;
Pavlin Radoslavov5ab68512013-02-18 09:59:33 -08002
HIGUCHI Yutaedf81d72013-06-12 12:06:57 -07003import net.onrc.onos.ofcontroller.flowcache.IFlowService;
HIGUCHI Yuta356086e2013-06-12 15:21:19 -07004import net.onrc.onos.ofcontroller.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}