blob: 3aea9a4bec0cd25907e257fe99857e313132a288 [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
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080026 @Override
27 protected void finalize() {
Pankaj Berde15193092013-03-21 17:30:14 -070028 close();
29 }
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080030
Pankaj Berde15193092013-03-21 17:30:14 -070031 @Override
32 public void close() {
yoshi2db7ff42013-11-25 19:30:25 -080033 dbop.close();
Pankaj Berde15193092013-03-21 17:30:14 -070034 }
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080035
Pankaj Berde5024ec12013-01-31 17:07:29 -080036 @Override
Pankaj Berde1cde50b2013-02-19 20:16:06 -080037 public List<Link> getActiveLinks() {
Yoshi Muroi815c7f92014-01-30 18:06:16 -080038 dbop = GraphDBManager.getDBOperation("ramcloud", "/tmp/ramcloud.conf");
yoshid38cd312013-12-02 19:54:44 -080039 //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);
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080050
Pankaj Berde15193092013-03-21 17:30:14 -070051 while (pipe.hasNext() ) {
52 Link l = pipe.next();
53 links.add(l);
54 }
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080055
Pankaj Berde15193092013-03-21 17:30:14 -070056 }
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);
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080071
Pankaj Berde15193092013-03-21 17:30:14 -070072 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
Naoki Shiotadf051d42014-01-20 16:12:41 -080080 private static class ExtractLink implements PipeFunction<PathPipe<Vertex>, Link> {
Naoki Shiota991093a2013-12-10 14:47:18 -080081 @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;
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080087
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");
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080097
Naoki Shiota991093a2013-12-10 14:47:18 -080098 Link l = new Link(s_dpid,s_port,d_dpid,d_port);
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080099
Naoki Shiota991093a2013-12-10 14:47:18 -0800100 return l;
101 }
102 }
Pankaj Berde5024ec12013-01-31 17:07:29 -0800103}