blob: 88d0663f7483ef08c78e3b72ae955fba149f1cc0 [file] [log] [blame]
tomdb0d03f2014-08-27 16:34:15 -07001package org.onlab.onos.net.trivial.impl;
2
alshabibdf652ad2014-09-09 11:53:19 -07003import static com.google.common.base.Preconditions.checkNotNull;
4import static org.slf4j.LoggerFactory.getLogger;
5
6import java.util.Set;
7
tomdb0d03f2014-08-27 16:34:15 -07008import org.apache.felix.scr.annotations.Activate;
9import org.apache.felix.scr.annotations.Component;
10import org.apache.felix.scr.annotations.Deactivate;
tom5f38b3a2014-08-27 23:50:54 -070011import org.apache.felix.scr.annotations.Reference;
12import org.apache.felix.scr.annotations.ReferenceCardinality;
tomdb0d03f2014-08-27 16:34:15 -070013import org.apache.felix.scr.annotations.Service;
tom96dfcab2014-08-28 09:26:03 -070014import org.onlab.onos.event.AbstractListenerRegistry;
15import org.onlab.onos.event.EventDeliveryService;
tomeadbb462014-09-07 16:10:19 -070016import org.onlab.onos.net.ConnectPoint;
17import org.onlab.onos.net.DeviceId;
18import org.onlab.onos.net.Link;
19import org.onlab.onos.net.link.LinkAdminService;
tomdb0d03f2014-08-27 16:34:15 -070020import org.onlab.onos.net.link.LinkDescription;
tom5f38b3a2014-08-27 23:50:54 -070021import org.onlab.onos.net.link.LinkEvent;
22import org.onlab.onos.net.link.LinkListener;
tomdb0d03f2014-08-27 16:34:15 -070023import org.onlab.onos.net.link.LinkProvider;
tom96dfcab2014-08-28 09:26:03 -070024import org.onlab.onos.net.link.LinkProviderRegistry;
tomdb0d03f2014-08-27 16:34:15 -070025import org.onlab.onos.net.link.LinkProviderService;
tomeadbb462014-09-07 16:10:19 -070026import org.onlab.onos.net.link.LinkService;
tom96dfcab2014-08-28 09:26:03 -070027import org.onlab.onos.net.provider.AbstractProviderRegistry;
tomdb0d03f2014-08-27 16:34:15 -070028import org.onlab.onos.net.provider.AbstractProviderService;
29import org.slf4j.Logger;
tom5f38b3a2014-08-27 23:50:54 -070030
alshabibdf652ad2014-09-09 11:53:19 -070031import com.google.common.collect.Sets;
tomdb0d03f2014-08-27 16:34:15 -070032
33/**
34 * Provides basic implementation of the link SB & NB APIs.
35 */
36@Component(immediate = true)
37@Service
tom5f38b3a2014-08-27 23:50:54 -070038public class SimpleLinkManager
alshabibdf652ad2014-09-09 11:53:19 -070039extends AbstractProviderRegistry<LinkProvider, LinkProviderService>
40implements LinkService, LinkAdminService, LinkProviderRegistry {
tomeadbb462014-09-07 16:10:19 -070041
42 private static final String DEVICE_ID_NULL = "Device ID cannot be null";
43 private static final String LINK_DESC_NULL = "Link description cannot be null";
44 private static final String CONNECT_POINT_NULL = "Connection point cannot be null";
tomdb0d03f2014-08-27 16:34:15 -070045
tom5f38b3a2014-08-27 23:50:54 -070046 private final Logger log = getLogger(getClass());
tomdb0d03f2014-08-27 16:34:15 -070047
tom96dfcab2014-08-28 09:26:03 -070048 private final AbstractListenerRegistry<LinkEvent, LinkListener>
alshabibdf652ad2014-09-09 11:53:19 -070049 listenerRegistry = new AbstractListenerRegistry<>();
tom5f38b3a2014-08-27 23:50:54 -070050
tom4c6606f2014-09-07 11:11:21 -070051 private final SimpleLinkStore store = new SimpleLinkStore();
52
tom5f38b3a2014-08-27 23:50:54 -070053 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
tom0d395262014-09-07 16:53:40 -070054 protected EventDeliveryService eventDispatcher;
tomdb0d03f2014-08-27 16:34:15 -070055
56 @Activate
57 public void activate() {
tom96dfcab2014-08-28 09:26:03 -070058 eventDispatcher.addSink(LinkEvent.class, listenerRegistry);
tomdb0d03f2014-08-27 16:34:15 -070059 log.info("Started");
60 }
61
62 @Deactivate
63 public void deactivate() {
tom5f38b3a2014-08-27 23:50:54 -070064 eventDispatcher.removeSink(LinkEvent.class);
tomdb0d03f2014-08-27 16:34:15 -070065 log.info("Stopped");
66 }
67
68 @Override
tom5f38b3a2014-08-27 23:50:54 -070069 protected LinkProviderService createProviderService(LinkProvider provider) {
70 return new InternalLinkProviderService(provider);
tomdb0d03f2014-08-27 16:34:15 -070071 }
72
tomeadbb462014-09-07 16:10:19 -070073 @Override
74 public int getLinkCount() {
75 return store.getLinkCount();
76 }
77
78 @Override
79 public Iterable<Link> getLinks() {
80 return store.getLinks();
81 }
82
83 @Override
84 public Set<Link> getDeviceLinks(DeviceId deviceId) {
85 checkNotNull(deviceId, DEVICE_ID_NULL);
86 return Sets.union(store.getDeviceEgressLinks(deviceId),
alshabibdf652ad2014-09-09 11:53:19 -070087 store.getDeviceIngressLinks(deviceId));
tomeadbb462014-09-07 16:10:19 -070088 }
89
90 @Override
91 public Set<Link> getDeviceEgressLinks(DeviceId deviceId) {
92 checkNotNull(deviceId, DEVICE_ID_NULL);
93 return store.getDeviceEgressLinks(deviceId);
94 }
95
96 @Override
tomd176fc42014-09-08 00:12:30 -070097 public Set<Link> getDeviceIngressLinks(DeviceId deviceId) {
tomeadbb462014-09-07 16:10:19 -070098 checkNotNull(deviceId, DEVICE_ID_NULL);
99 return store.getDeviceIngressLinks(deviceId);
100 }
101
102 @Override
103 public Set<Link> getLinks(ConnectPoint connectPoint) {
104 checkNotNull(connectPoint, CONNECT_POINT_NULL);
105 return Sets.union(store.getEgressLinks(connectPoint),
alshabibdf652ad2014-09-09 11:53:19 -0700106 store.getIngressLinks(connectPoint));
tomeadbb462014-09-07 16:10:19 -0700107 }
108
109 @Override
110 public Set<Link> getEgressLinks(ConnectPoint connectPoint) {
111 checkNotNull(connectPoint, CONNECT_POINT_NULL);
112 return store.getEgressLinks(connectPoint);
113 }
114
115 @Override
tomd176fc42014-09-08 00:12:30 -0700116 public Set<Link> getIngressLinks(ConnectPoint connectPoint) {
tomeadbb462014-09-07 16:10:19 -0700117 checkNotNull(connectPoint, CONNECT_POINT_NULL);
118 return store.getIngressLinks(connectPoint);
119 }
120
121 @Override
tomd176fc42014-09-08 00:12:30 -0700122 public Link getLink(ConnectPoint src, ConnectPoint dst) {
tomeadbb462014-09-07 16:10:19 -0700123 checkNotNull(src, CONNECT_POINT_NULL);
124 checkNotNull(dst, CONNECT_POINT_NULL);
tomd176fc42014-09-08 00:12:30 -0700125 return store.getLink(src, dst);
tomeadbb462014-09-07 16:10:19 -0700126 }
127
128 @Override
129 public void removeLinks(ConnectPoint connectPoint) {
130 removeLinks(getLinks(connectPoint));
131 }
132
133 @Override
134 public void removeLinks(DeviceId deviceId) {
135 removeLinks(getDeviceLinks(deviceId));
136 }
137
138 @Override
139 public void addListener(LinkListener listener) {
140 listenerRegistry.addListener(listener);
141 }
142
143 @Override
144 public void removeListener(LinkListener listener) {
145 listenerRegistry.removeListener(listener);
146 }
147
tomdb0d03f2014-08-27 16:34:15 -0700148 // Personalized link provider service issued to the supplied provider.
149 private class InternalLinkProviderService extends AbstractProviderService<LinkProvider>
alshabibdf652ad2014-09-09 11:53:19 -0700150 implements LinkProviderService {
tomdb0d03f2014-08-27 16:34:15 -0700151
tomcfde0622014-09-09 11:02:42 -0700152 InternalLinkProviderService(LinkProvider provider) {
tomdb0d03f2014-08-27 16:34:15 -0700153 super(provider);
154 }
155
156 @Override
157 public void linkDetected(LinkDescription linkDescription) {
tomeadbb462014-09-07 16:10:19 -0700158 checkNotNull(linkDescription, LINK_DESC_NULL);
159 checkValidity();
alshabibdf652ad2014-09-09 11:53:19 -0700160 log.debug("Link {} detected", linkDescription);
tomeadbb462014-09-07 16:10:19 -0700161 LinkEvent event = store.createOrUpdateLink(provider().id(),
alshabibdf652ad2014-09-09 11:53:19 -0700162 linkDescription);
tomeadbb462014-09-07 16:10:19 -0700163 post(event);
tomdb0d03f2014-08-27 16:34:15 -0700164 }
165
166 @Override
167 public void linkVanished(LinkDescription linkDescription) {
tomeadbb462014-09-07 16:10:19 -0700168 checkNotNull(linkDescription, LINK_DESC_NULL);
169 checkValidity();
tomdb0d03f2014-08-27 16:34:15 -0700170 log.info("Link {} vanished", linkDescription);
tomeadbb462014-09-07 16:10:19 -0700171 LinkEvent event = store.removeLink(linkDescription.src(),
alshabibdf652ad2014-09-09 11:53:19 -0700172 linkDescription.dst());
tomeadbb462014-09-07 16:10:19 -0700173 post(event);
174 }
175
176 @Override
177 public void linksVanished(ConnectPoint connectPoint) {
178 checkNotNull(connectPoint, "Connect point cannot be null");
179 checkValidity();
180 log.info("Link for connection point {} vanished", connectPoint);
181 removeLinks(getLinks(connectPoint));
182 }
183
184 @Override
185 public void linksVanished(DeviceId deviceId) {
186 checkNotNull(deviceId, DEVICE_ID_NULL);
187 checkValidity();
188 log.info("Link for device {} vanished", deviceId);
189 removeLinks(getDeviceLinks(deviceId));
tomdb0d03f2014-08-27 16:34:15 -0700190 }
191 }
tomeadbb462014-09-07 16:10:19 -0700192
193 // Removes all links in the specified set and emits appropriate events.
194 private void removeLinks(Set<Link> links) {
195 for (Link link : links) {
196 LinkEvent event = store.removeLink(link.src(), link.dst());
197 post(event);
198 }
199 }
200
201 // Posts the specified event to the local event dispatcher.
202 private void post(LinkEvent event) {
203 if (event != null && eventDispatcher != null) {
204 eventDispatcher.post(event);
205 }
206 }
207
tomdb0d03f2014-08-27 16:34:15 -0700208}