blob: 3a6db70ef32ba2de08550c2fa542b62f7911b1f0 [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() {
Pankaj Berde5024ec12013-01-31 17:07:29 -080038 // TODO Auto-generated method stub
yoshib6a66eb2014-01-21 10:11:49 -080039 dbop = GraphDBManager.getDBOperation("ramcloud", "/tmp/ramcloud.conf");
yoshid38cd312013-12-02 19:54:44 -080040 //dbop = GraphDBManager.getDBOperation("", "");
yoshi9535fc82013-12-05 11:34:52 -080041 //dbop.commit(); //Commit to ensure we see latest data
yoshi2db7ff42013-11-25 19:30:25 -080042 Iterable<ISwitchObject> switches = dbop.getActiveSwitches();
Pankaj Berde15193092013-03-21 17:30:14 -070043 List<Link> links = new ArrayList<Link>();
44 for (ISwitchObject sw : switches) {
45 GremlinPipeline<Vertex, Link> pipe = new GremlinPipeline<Vertex, Link>();
46 ExtractLink extractor = new ExtractLink();
47
48 pipe.start(sw.asVertex());
49 pipe.enablePath(true);
50 pipe.out("on").out("link").in("on").path().step(extractor);
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080051
Pankaj Berde15193092013-03-21 17:30:14 -070052 while (pipe.hasNext() ) {
53 Link l = pipe.next();
54 links.add(l);
55 }
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080056
Pankaj Berde15193092013-03-21 17:30:14 -070057 }
yoshi2db7ff42013-11-25 19:30:25 -080058 dbop.commit();
Pankaj Berde15193092013-03-21 17:30:14 -070059 return links;
Pankaj Berde5024ec12013-01-31 17:07:29 -080060 }
61
62 @Override
Pankaj Berde1cde50b2013-02-19 20:16:06 -080063 public List<Link> getLinksOnSwitch(String dpid) {
Pankaj Berde15193092013-03-21 17:30:14 -070064 List<Link> links = new ArrayList<Link>();
yoshi2db7ff42013-11-25 19:30:25 -080065 ISwitchObject sw = dbop.searchSwitch(dpid);
Pankaj Berde15193092013-03-21 17:30:14 -070066 GremlinPipeline<Vertex, Link> pipe = new GremlinPipeline<Vertex, Link>();
67 ExtractLink extractor = new ExtractLink();
68
69 pipe.start(sw.asVertex());
70 pipe.enablePath(true);
71 pipe.out("on").out("link").in("on").path().step(extractor);
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080072
Pankaj Berde15193092013-03-21 17:30:14 -070073 while (pipe.hasNext() ) {
74 Link l = pipe.next();
75 links.add(l);
76 }
77 return links;
78
Pankaj Berde5024ec12013-01-31 17:07:29 -080079 }
Naoki Shiota991093a2013-12-10 14:47:18 -080080
Naoki Shiotadf051d42014-01-20 16:12:41 -080081 private static class ExtractLink implements PipeFunction<PathPipe<Vertex>, Link> {
Naoki Shiota991093a2013-12-10 14:47:18 -080082 @Override
83 public Link compute(PathPipe<Vertex> pipe) {
84 long s_dpid = 0;
85 long d_dpid = 0;
86 short s_port = 0;
87 short d_port = 0;
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080088
Naoki Shiotade5d8422013-12-11 13:56:57 -080089 List<?> V = pipe.next();
90 Vertex src_sw = (Vertex)V.get(0);
91 Vertex dest_sw = (Vertex)V.get(3);
92 Vertex src_port = (Vertex)V.get(1);
93 Vertex dest_port = (Vertex)V.get(2);
Naoki Shiota991093a2013-12-10 14:47:18 -080094 s_dpid = HexString.toLong((String) src_sw.getProperty("dpid"));
95 d_dpid = HexString.toLong((String) dest_sw.getProperty("dpid"));
96 s_port = (Short) src_port.getProperty("number");
97 d_port = (Short) dest_port.getProperty("number");
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -080098
Naoki Shiota991093a2013-12-10 14:47:18 -080099 Link l = new Link(s_dpid,s_port,d_dpid,d_port);
Yuta HIGUCHI67a7a3e2014-01-03 14:51:34 -0800100
Naoki Shiota991093a2013-12-10 14:47:18 -0800101 return l;
102 }
103 }
Pankaj Berde5024ec12013-01-31 17:07:29 -0800104}