HIGUCHI Yuta | f05c480 | 2013-06-17 11:15:50 -0700 | [diff] [blame] | 1 | package net.onrc.onos.ofcontroller.core.internal; |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 2 | |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 3 | import java.util.ArrayList; |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 4 | import java.util.List; |
| 5 | |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 6 | import net.floodlightcontroller.routing.Link; |
Pankaj Berde | 38646d6 | 2013-06-21 11:34:04 -0700 | [diff] [blame] | 7 | import net.onrc.onos.graph.GraphDBOperation; |
HIGUCHI Yuta | 2051490 | 2013-06-12 11:24:16 -0700 | [diff] [blame] | 8 | import net.onrc.onos.ofcontroller.core.INetMapTopologyObjects.ISwitchObject; |
| 9 | import net.onrc.onos.ofcontroller.core.INetMapTopologyService.ITopoLinkService; |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 10 | |
Naoki Shiota | 991093a | 2013-12-10 14:47:18 -0800 | [diff] [blame] | 11 | import org.openflow.util.HexString; |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 12 | import org.slf4j.Logger; |
| 13 | import org.slf4j.LoggerFactory; |
| 14 | |
| 15 | import com.tinkerpop.blueprints.Vertex; |
| 16 | import com.tinkerpop.gremlin.java.GremlinPipeline; |
Naoki Shiota | 991093a | 2013-12-10 14:47:18 -0800 | [diff] [blame] | 17 | import com.tinkerpop.pipes.PipeFunction; |
| 18 | import com.tinkerpop.pipes.transform.PathPipe; |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 19 | |
| 20 | public class TopoLinkServiceImpl implements ITopoLinkService { |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 21 | |
Toshio Koide | 22f192c | 2013-06-13 14:01:45 -0700 | [diff] [blame] | 22 | protected GraphDBOperation op; |
Yuta HIGUCHI | 6ac8d18 | 2013-10-22 15:24:56 -0700 | [diff] [blame] | 23 | protected final static Logger log = LoggerFactory.getLogger(TopoLinkServiceImpl.class); |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 24 | |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 25 | @Override |
| 26 | protected void finalize() { |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 27 | close(); |
| 28 | } |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 29 | |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 30 | @Override |
| 31 | public void close() { |
Toshio Koide | 22f192c | 2013-06-13 14:01:45 -0700 | [diff] [blame] | 32 | op.close(); |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 33 | } |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 34 | |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 35 | @Override |
Pankaj Berde | 1cde50b | 2013-02-19 20:16:06 -0800 | [diff] [blame] | 36 | public List<Link> getActiveLinks() { |
Toshio Koide | bfe9b92 | 2013-06-18 10:56:05 -0700 | [diff] [blame] | 37 | op = new GraphDBOperation(""); |
| 38 | op.commit(); //Commit to ensure we see latest data |
Toshio Koide | 22f192c | 2013-06-13 14:01:45 -0700 | [diff] [blame] | 39 | Iterable<ISwitchObject> switches = op.getActiveSwitches(); |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 40 | List<Link> links = new ArrayList<Link>(); |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 41 | for (ISwitchObject sw : switches) { |
| 42 | GremlinPipeline<Vertex, Link> pipe = new GremlinPipeline<Vertex, Link>(); |
| 43 | ExtractLink extractor = new ExtractLink(); |
| 44 | |
| 45 | pipe.start(sw.asVertex()); |
| 46 | pipe.enablePath(true); |
| 47 | pipe.out("on").out("link").in("on").path().step(extractor); |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 48 | |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 49 | while (pipe.hasNext() ) { |
| 50 | Link l = pipe.next(); |
| 51 | links.add(l); |
| 52 | } |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 53 | |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 54 | } |
Toshio Koide | 22f192c | 2013-06-13 14:01:45 -0700 | [diff] [blame] | 55 | op.commit(); |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 56 | return links; |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 57 | } |
| 58 | |
| 59 | @Override |
Pankaj Berde | 1cde50b | 2013-02-19 20:16:06 -0800 | [diff] [blame] | 60 | public List<Link> getLinksOnSwitch(String dpid) { |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 61 | List<Link> links = new ArrayList<Link>(); |
Toshio Koide | 22f192c | 2013-06-13 14:01:45 -0700 | [diff] [blame] | 62 | ISwitchObject sw = op.searchSwitch(dpid); |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 63 | GremlinPipeline<Vertex, Link> pipe = new GremlinPipeline<Vertex, Link>(); |
| 64 | ExtractLink extractor = new ExtractLink(); |
| 65 | |
| 66 | pipe.start(sw.asVertex()); |
| 67 | pipe.enablePath(true); |
| 68 | pipe.out("on").out("link").in("on").path().step(extractor); |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 69 | |
Pankaj Berde | 1519309 | 2013-03-21 17:30:14 -0700 | [diff] [blame] | 70 | while (pipe.hasNext() ) { |
| 71 | Link l = pipe.next(); |
| 72 | links.add(l); |
| 73 | } |
| 74 | return links; |
| 75 | |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 76 | } |
Naoki Shiota | 991093a | 2013-12-10 14:47:18 -0800 | [diff] [blame] | 77 | |
| 78 | private class ExtractLink implements PipeFunction<PathPipe<Vertex>, Link> { |
| 79 | @Override |
| 80 | public Link compute(PathPipe<Vertex> pipe) { |
| 81 | long s_dpid = 0; |
| 82 | long d_dpid = 0; |
| 83 | short s_port = 0; |
| 84 | short d_port = 0; |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 85 | |
Naoki Shiota | de5d842 | 2013-12-11 13:56:57 -0800 | [diff] [blame] | 86 | List<?> V = pipe.next(); |
| 87 | Vertex src_sw = (Vertex)V.get(0); |
| 88 | Vertex dest_sw = (Vertex)V.get(3); |
| 89 | Vertex src_port = (Vertex)V.get(1); |
| 90 | Vertex dest_port = (Vertex)V.get(2); |
Naoki Shiota | 991093a | 2013-12-10 14:47:18 -0800 | [diff] [blame] | 91 | s_dpid = HexString.toLong((String) src_sw.getProperty("dpid")); |
| 92 | d_dpid = HexString.toLong((String) dest_sw.getProperty("dpid")); |
| 93 | s_port = (Short) src_port.getProperty("number"); |
| 94 | d_port = (Short) dest_port.getProperty("number"); |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 95 | |
Naoki Shiota | 991093a | 2013-12-10 14:47:18 -0800 | [diff] [blame] | 96 | Link l = new Link(s_dpid,s_port,d_dpid,d_port); |
Yuta HIGUCHI | 67a7a3e | 2014-01-03 14:51:34 -0800 | [diff] [blame] | 97 | |
Naoki Shiota | 991093a | 2013-12-10 14:47:18 -0800 | [diff] [blame] | 98 | return l; |
| 99 | } |
| 100 | } |
Pankaj Berde | 5024ec1 | 2013-01-31 17:07:29 -0800 | [diff] [blame] | 101 | } |