blob: cf73c9cfbccfd1241245b56e7e5c258a0ee9f751 [file] [log] [blame]
HIGUCHI Yutaf05c4802013-06-17 11:15:50 -07001package net.onrc.onos.ofcontroller.core.internal;
Pankaj Berde5024ec12013-01-31 17:07:29 -08002
Pankaj Berde15193092013-03-21 17:30:14 -07003import java.util.ArrayList;
Pankaj Berde5024ec12013-01-31 17:07:29 -08004import java.util.List;
5
Pankaj Berde5024ec12013-01-31 17:07:29 -08006import net.floodlightcontroller.routing.Link;
yoshi2db7ff42013-11-25 19:30:25 -08007import net.onrc.onos.graph.DBOperation;
HIGUCHI Yuta20514902013-06-12 11:24:16 -07008import net.onrc.onos.ofcontroller.core.INetMapTopologyObjects.ISwitchObject;
9import net.onrc.onos.ofcontroller.core.INetMapTopologyService.ITopoLinkService;
Pankaj Berde15193092013-03-21 17:30:14 -070010
Naoki Shiota991093a2013-12-10 14:47:18 -080011import org.openflow.util.HexString;
Pankaj Berde15193092013-03-21 17:30:14 -070012import org.slf4j.Logger;
13import org.slf4j.LoggerFactory;
14
15import com.tinkerpop.blueprints.Vertex;
16import com.tinkerpop.gremlin.java.GremlinPipeline;
yoshi2db7ff42013-11-25 19:30:25 -080017import net.onrc.onos.graph.GraphDBManager;
Naoki Shiota991093a2013-12-10 14:47:18 -080018import com.tinkerpop.pipes.PipeFunction;
19import com.tinkerpop.pipes.transform.PathPipe;
Pankaj Berde5024ec12013-01-31 17:07:29 -080020
21public class TopoLinkServiceImpl implements ITopoLinkService {
22
yoshi2db7ff42013-11-25 19:30:25 -080023 protected DBOperation dbop;
Yuta HIGUCHI6ac8d182013-10-22 15:24:56 -070024 protected final static Logger log = LoggerFactory.getLogger(TopoLinkServiceImpl.class);
Pankaj Berde15193092013-03-21 17:30:14 -070025
Pankaj Berde15193092013-03-21 17:30:14 -070026 public void finalize() {
27 close();
28 }
29
30 @Override
31 public void close() {
yoshi2db7ff42013-11-25 19:30:25 -080032 dbop.close();
Pankaj Berde15193092013-03-21 17:30:14 -070033 }
Pankaj Berde5024ec12013-01-31 17:07:29 -080034
Pankaj Berde5024ec12013-01-31 17:07:29 -080035 @Override
Pankaj Berde1cde50b2013-02-19 20:16:06 -080036 public List<Link> getActiveLinks() {
Pankaj Berde5024ec12013-01-31 17:07:29 -080037 // TODO Auto-generated method stub
yoshid38cd312013-12-02 19:54:44 -080038 dbop = GraphDBManager.getDBOperation("ramcloud", "/tmp/ramcloudconf");
39 //dbop = GraphDBManager.getDBOperation("", "");
yoshi9535fc82013-12-05 11:34:52 -080040 //dbop.commit(); //Commit to ensure we see latest data
yoshi2db7ff42013-11-25 19:30:25 -080041 Iterable<ISwitchObject> switches = dbop.getActiveSwitches();
Pankaj Berde15193092013-03-21 17:30:14 -070042 List<Link> links = new ArrayList<Link>();
43 for (ISwitchObject sw : switches) {
44 GremlinPipeline<Vertex, Link> pipe = new GremlinPipeline<Vertex, Link>();
45 ExtractLink extractor = new ExtractLink();
46
47 pipe.start(sw.asVertex());
48 pipe.enablePath(true);
49 pipe.out("on").out("link").in("on").path().step(extractor);
50
51 while (pipe.hasNext() ) {
52 Link l = pipe.next();
53 links.add(l);
54 }
55
56 }
yoshi2db7ff42013-11-25 19:30:25 -080057 dbop.commit();
Pankaj Berde15193092013-03-21 17:30:14 -070058 return links;
Pankaj Berde5024ec12013-01-31 17:07:29 -080059 }
60
61 @Override
Pankaj Berde1cde50b2013-02-19 20:16:06 -080062 public List<Link> getLinksOnSwitch(String dpid) {
Pankaj Berde15193092013-03-21 17:30:14 -070063 List<Link> links = new ArrayList<Link>();
yoshi2db7ff42013-11-25 19:30:25 -080064 ISwitchObject sw = dbop.searchSwitch(dpid);
Pankaj Berde15193092013-03-21 17:30:14 -070065 GremlinPipeline<Vertex, Link> pipe = new GremlinPipeline<Vertex, Link>();
66 ExtractLink extractor = new ExtractLink();
67
68 pipe.start(sw.asVertex());
69 pipe.enablePath(true);
70 pipe.out("on").out("link").in("on").path().step(extractor);
71
72 while (pipe.hasNext() ) {
73 Link l = pipe.next();
74 links.add(l);
75 }
76 return links;
77
Pankaj Berde5024ec12013-01-31 17:07:29 -080078 }
Naoki Shiota991093a2013-12-10 14:47:18 -080079
80 private class ExtractLink implements PipeFunction<PathPipe<Vertex>, Link> {
81 @Override
82 public Link compute(PathPipe<Vertex> pipe) {
83 long s_dpid = 0;
84 long d_dpid = 0;
85 short s_port = 0;
86 short d_port = 0;
87
Naoki Shiotade5d8422013-12-11 13:56:57 -080088 List<?> V = pipe.next();
89 Vertex src_sw = (Vertex)V.get(0);
90 Vertex dest_sw = (Vertex)V.get(3);
91 Vertex src_port = (Vertex)V.get(1);
92 Vertex dest_port = (Vertex)V.get(2);
Naoki Shiota991093a2013-12-10 14:47:18 -080093 s_dpid = HexString.toLong((String) src_sw.getProperty("dpid"));
94 d_dpid = HexString.toLong((String) dest_sw.getProperty("dpid"));
95 s_port = (Short) src_port.getProperty("number");
96 d_port = (Short) dest_port.getProperty("number");
97
98 Link l = new Link(s_dpid,s_port,d_dpid,d_port);
99
100 return l;
101 }
102 }
Pankaj Berde5024ec12013-01-31 17:07:29 -0800103}