blob: 88890921c096cf086325848719678264ca8c59c1 [file] [log] [blame]
HIGUCHI Yuta2d011582013-06-15 01:47:11 -07001package net.onrc.onos.ofcontroller.core;
Pankaj Berdee73452c2013-01-03 14:57:07 -08002
3import java.util.List;
4
Pankaj Berdee73452c2013-01-03 14:57:07 -08005import net.floodlightcontroller.routing.Link;
HIGUCHI Yutaa56fbde2013-06-17 14:26:05 -07006import net.onrc.onos.ofcontroller.linkdiscovery.LinkInfo;
Pankaj Berdee73452c2013-01-03 14:57:07 -08007
8public interface ILinkStorage extends INetMapStorage {
9
10 /*
Naoki Shiotab2d17e82013-10-18 18:08:16 -070011 * Init with Storage conf
Pankaj Berdee73452c2013-01-03 14:57:07 -080012 */
Naoki Shiotab2d17e82013-10-18 18:08:16 -070013 public void init(String conf);
Pankaj Berdee73452c2013-01-03 14:57:07 -080014
15 /*
Naoki Shiotab2d17e82013-10-18 18:08:16 -070016 * Generic operation method
17 */
Naoki Shiota987a5722013-10-23 11:59:36 -070018 public boolean update(Link link, LinkInfo linkinfo, DM_OPERATION op);
Naoki Shiotab2d17e82013-10-18 18:08:16 -070019
20 /*
21 * Link creation
22 */
Naoki Shiota987a5722013-10-23 11:59:36 -070023 public boolean addLink(Link link);
24 public boolean addLink(Link link, LinkInfo linfo);
25 public boolean addLinks(List<Link> links);
Naoki Shiotab2d17e82013-10-18 18:08:16 -070026
27 /*
28 * Link deletion
Pankaj Berdee73452c2013-01-03 14:57:07 -080029 */
Naoki Shiota987a5722013-10-23 11:59:36 -070030 public boolean deleteLink(Link link);
31 public boolean deleteLinks(List<Link> links);
Pankaj Berdee73452c2013-01-03 14:57:07 -080032
33 /*
Naoki Shiotab2d17e82013-10-18 18:08:16 -070034 * Utility method to delete links associated with dpid and port
Pankaj Berdee73452c2013-01-03 14:57:07 -080035 * If only dpid is used, All links associated for switch are removed
36 * Useful for port up/down and also switch join/remove events
37 */
Naoki Shiota987a5722013-10-23 11:59:36 -070038 public boolean deleteLinksOnPort(Long dpid, short port);
Umesh Krishnaswamyf962d642013-01-23 19:04:23 -080039
40 /*
41 * Get Links from Storage
42 * If dpid and port both are specified specific link is retrieved
43 * If only dpid is set all links associated with Switch are retrieved
44 */
45 public List<Link> getLinks(Long dpid, short port);
Pavlin Radoslavovc934b4a2013-11-02 14:53:52 -070046
Pavlin Radoslavov43781cd2013-11-04 18:19:10 -080047 /**
48 * Get list of all reverse links connected to the port specified by given DPID and port number.
49 * @param dpid DPID of desired port.
50 * @param port Port number of desired port.
51 * @return List of reverse links. Empty list if no port was found.
52 */
53 public List<Link> getReverseLinks(Long dpid, short port);
54
Pankaj Berdeff421802013-01-29 20:28:52 -080055 public List<Link> getLinks(String dpid);
Pavlin Radoslavovc934b4a2013-11-02 14:53:52 -070056
57 /**
58 * Get list of all reverse links connected to the switch specified by
59 * given DPID.
60 * @param dpid DPID of desired switch.
61 * @return List of reverse links. Empty list if no port was found.
62 */
63 public List<Link> getReverseLinks(String dpid);
64
Pankaj Berdeff421802013-01-29 20:28:52 -080065 public List<Link> getActiveLinks();
Pankaj Berdeff421802013-01-29 20:28:52 -080066
Naoki Shiotab2d17e82013-10-18 18:08:16 -070067 public LinkInfo getLinkInfo(Link link);
Pankaj Berdee73452c2013-01-03 14:57:07 -080068}