blob: 1473f33f636f6a65a3e67a335aca50b9c841967b [file] [log] [blame]
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07001/*
2 * Copyright 2014 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Brian O'Connorabafb502014-12-02 22:26:20 -080016package org.onosproject.net.host.impl;
tomdb0d03f2014-08-27 16:34:15 -070017
18import org.apache.felix.scr.annotations.Activate;
19import org.apache.felix.scr.annotations.Component;
20import org.apache.felix.scr.annotations.Deactivate;
tom5f38b3a2014-08-27 23:50:54 -070021import org.apache.felix.scr.annotations.Reference;
22import org.apache.felix.scr.annotations.ReferenceCardinality;
tomdb0d03f2014-08-27 16:34:15 -070023import org.apache.felix.scr.annotations.Service;
Simon Huntff663742015-05-14 13:33:05 -070024import org.onlab.packet.IpAddress;
25import org.onlab.packet.MacAddress;
26import org.onlab.packet.VlanId;
Jonathan Hart4cb39882015-08-12 23:50:55 -040027import org.onosproject.incubator.net.intf.InterfaceService;
Jonathan Hartfb32a6e2015-09-01 12:12:14 +020028import org.onosproject.net.edge.EdgePortService;
Thomas Vachuska42e8cce2015-07-29 19:25:18 -070029import org.onosproject.net.provider.AbstractListenerProviderRegistry;
Ray Milkeya4122362015-08-18 15:19:08 -070030import org.onosproject.net.config.NetworkConfigEvent;
31import org.onosproject.net.config.NetworkConfigListener;
32import org.onosproject.net.config.NetworkConfigService;
Thomas Vachuska4998caa2015-08-26 13:28:38 -070033import org.onosproject.net.config.basics.BasicHostConfig;
Brian O'Connorabafb502014-12-02 22:26:20 -080034import org.onosproject.net.ConnectPoint;
35import org.onosproject.net.DeviceId;
36import org.onosproject.net.Host;
37import org.onosproject.net.HostId;
38import org.onosproject.net.device.DeviceService;
39import org.onosproject.net.host.HostAdminService;
40import org.onosproject.net.host.HostDescription;
41import org.onosproject.net.host.HostEvent;
42import org.onosproject.net.host.HostListener;
43import org.onosproject.net.host.HostProvider;
44import org.onosproject.net.host.HostProviderRegistry;
45import org.onosproject.net.host.HostProviderService;
46import org.onosproject.net.host.HostService;
47import org.onosproject.net.host.HostStore;
48import org.onosproject.net.host.HostStoreDelegate;
Brian O'Connorabafb502014-12-02 22:26:20 -080049import org.onosproject.net.packet.PacketService;
Brian O'Connorabafb502014-12-02 22:26:20 -080050import org.onosproject.net.provider.AbstractProviderService;
tomdb0d03f2014-08-27 16:34:15 -070051import org.slf4j.Logger;
tom5f38b3a2014-08-27 23:50:54 -070052
Simon Huntff663742015-05-14 13:33:05 -070053import java.util.Set;
54
55import static com.google.common.base.Preconditions.checkNotNull;
Sahil Lele3a0cdd52015-07-21 14:16:31 -070056import static com.google.common.base.Preconditions.checkState;
Changhoon Yoon541ef712015-05-23 17:18:34 +090057import static org.onosproject.security.AppGuard.checkPermission;
Thomas Vachuska42e8cce2015-07-29 19:25:18 -070058import static org.slf4j.LoggerFactory.getLogger;
Changhoon Yoonb856b812015-08-10 03:47:19 +090059import static org.onosproject.security.AppPermission.Type.*;
Simon Huntff663742015-05-14 13:33:05 -070060
tomdb0d03f2014-08-27 16:34:15 -070061/**
62 * Provides basic implementation of the host SB & NB APIs.
63 */
64@Component(immediate = true)
65@Service
tom202175a2014-09-19 19:00:11 -070066public class HostManager
Thomas Vachuska42e8cce2015-07-29 19:25:18 -070067 extends AbstractListenerProviderRegistry<HostEvent, HostListener, HostProvider, HostProviderService>
tom89b63c52014-09-16 09:19:51 -070068 implements HostService, HostAdminService, HostProviderRegistry {
tomdb0d03f2014-08-27 16:34:15 -070069
tom5f38b3a2014-08-27 23:50:54 -070070 private final Logger log = getLogger(getClass());
tomdb0d03f2014-08-27 16:34:15 -070071
Thomas Vachuska42e8cce2015-07-29 19:25:18 -070072 public static final String HOST_ID_NULL = "Host ID cannot be null";
tom5f38b3a2014-08-27 23:50:54 -070073
Sahil Lele3a0cdd52015-07-21 14:16:31 -070074 private final NetworkConfigListener networkConfigListener = new InternalNetworkConfigListener();
75
tomc78acee2014-09-24 15:16:55 -070076 private HostStoreDelegate delegate = new InternalStoreDelegate();
77
tom5bcc9462014-09-19 10:11:31 -070078 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
79 protected HostStore store;
tom7869ad92014-09-09 14:32:08 -070080
tom5f38b3a2014-08-27 23:50:54 -070081 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
Jonathan Hart70da5122014-10-01 16:37:42 -070082 protected DeviceService deviceService;
83
84 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
85 protected PacketService packetService;
86
Sahil Lele3a0cdd52015-07-21 14:16:31 -070087 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
88 protected NetworkConfigService networkConfigService;
89
Jonathan Hart4cb39882015-08-12 23:50:55 -040090 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
91 protected InterfaceService interfaceService;
92
Jonathan Hartfb32a6e2015-09-01 12:12:14 +020093 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
94 protected EdgePortService edgePortService;
95
Jonathan Hart70da5122014-10-01 16:37:42 -070096 private HostMonitor monitor;
tomdb0d03f2014-08-27 16:34:15 -070097
98 @Activate
99 public void activate() {
tomc78acee2014-09-24 15:16:55 -0700100 store.setDelegate(delegate);
tom96dfcab2014-08-28 09:26:03 -0700101 eventDispatcher.addSink(HostEvent.class, listenerRegistry);
Sahil Lele3a0cdd52015-07-21 14:16:31 -0700102 networkConfigService.addListener(networkConfigListener);
Jonathan Hartfb32a6e2015-09-01 12:12:14 +0200103 monitor = new HostMonitor(packetService, this, interfaceService, edgePortService);
Jonathan Hart8f6f1ea2014-10-03 16:05:19 -0700104 monitor.start();
Thomas Vachuska42e8cce2015-07-29 19:25:18 -0700105 log.info("Started");
tomdb0d03f2014-08-27 16:34:15 -0700106 }
107
108 @Deactivate
109 public void deactivate() {
tomc78acee2014-09-24 15:16:55 -0700110 store.unsetDelegate(delegate);
tom5f38b3a2014-08-27 23:50:54 -0700111 eventDispatcher.removeSink(HostEvent.class);
Sahil Lele3a0cdd52015-07-21 14:16:31 -0700112 networkConfigService.removeListener(networkConfigListener);
tomdb0d03f2014-08-27 16:34:15 -0700113 log.info("Stopped");
114 }
115
116 @Override
tom5f38b3a2014-08-27 23:50:54 -0700117 protected HostProviderService createProviderService(HostProvider provider) {
Jonathan Hart70da5122014-10-01 16:37:42 -0700118 monitor.registerHostProvider(provider);
tom5f38b3a2014-08-27 23:50:54 -0700119 return new InternalHostProviderService(provider);
tomdb0d03f2014-08-27 16:34:15 -0700120 }
121
tom7869ad92014-09-09 14:32:08 -0700122 @Override
123 public int getHostCount() {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900124 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700125 return store.getHostCount();
126 }
127
128 @Override
129 public Iterable<Host> getHosts() {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900130 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700131 return store.getHosts();
132 }
133
134 @Override
135 public Host getHost(HostId hostId) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900136 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700137 checkNotNull(hostId, HOST_ID_NULL);
138 return store.getHost(hostId);
139 }
140
141 @Override
Ayaka Koshibea9c199f2014-09-16 16:21:40 -0700142 public Set<Host> getHostsByVlan(VlanId vlanId) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900143 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700144 return store.getHosts(vlanId);
145 }
146
147 @Override
Ayaka Koshibea9c199f2014-09-16 16:21:40 -0700148 public Set<Host> getHostsByMac(MacAddress mac) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900149 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700150 checkNotNull(mac, "MAC address cannot be null");
151 return store.getHosts(mac);
152 }
153
154 @Override
Pavlin Radoslavov33f228a2014-10-27 19:33:16 -0700155 public Set<Host> getHostsByIp(IpAddress ip) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900156 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700157 checkNotNull(ip, "IP address cannot be null");
158 return store.getHosts(ip);
159 }
160
161 @Override
162 public Set<Host> getConnectedHosts(ConnectPoint connectPoint) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900163 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700164 checkNotNull(connectPoint, "Connection point cannot be null");
165 return store.getConnectedHosts(connectPoint);
166 }
167
168 @Override
169 public Set<Host> getConnectedHosts(DeviceId deviceId) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900170 checkPermission(HOST_READ);
tom7869ad92014-09-09 14:32:08 -0700171 checkNotNull(deviceId, "Device ID cannot be null");
172 return store.getConnectedHosts(deviceId);
173 }
174
175 @Override
Jonathan Hartac60c082014-09-23 08:55:17 -0700176 public void startMonitoringIp(IpAddress ip) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900177 checkPermission(HOST_EVENT);
Jonathan Hart70da5122014-10-01 16:37:42 -0700178 monitor.addMonitoringFor(ip);
Jonathan Hartfca736c2014-09-19 17:26:59 -0700179 }
180
181 @Override
Jonathan Hartac60c082014-09-23 08:55:17 -0700182 public void stopMonitoringIp(IpAddress ip) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900183 checkPermission(HOST_EVENT);
Jonathan Hart70da5122014-10-01 16:37:42 -0700184 monitor.stopMonitoring(ip);
Jonathan Hartac60c082014-09-23 08:55:17 -0700185 }
186
187 @Override
188 public void requestMac(IpAddress ip) {
Thomas Vachuska42e8cce2015-07-29 19:25:18 -0700189 // FIXME!!!! Auto-generated method stub
tom7869ad92014-09-09 14:32:08 -0700190 }
191
tom89b63c52014-09-16 09:19:51 -0700192 @Override
193 public void removeHost(HostId hostId) {
194 checkNotNull(hostId, HOST_ID_NULL);
195 HostEvent event = store.removeHost(hostId);
196 if (event != null) {
tom89b63c52014-09-16 09:19:51 -0700197 post(event);
198 }
199 }
200
tomdb0d03f2014-08-27 16:34:15 -0700201 // Personalized host provider service issued to the supplied provider.
tom7869ad92014-09-09 14:32:08 -0700202 private class InternalHostProviderService
203 extends AbstractProviderService<HostProvider>
tomdb0d03f2014-08-27 16:34:15 -0700204 implements HostProviderService {
tomcfde0622014-09-09 11:02:42 -0700205 InternalHostProviderService(HostProvider provider) {
tomdb0d03f2014-08-27 16:34:15 -0700206 super(provider);
207 }
208
209 @Override
Brian O'Connorf107bd72015-09-21 15:31:03 -0700210 public void hostDetected(HostId hostId, HostDescription hostDescription, boolean replaceIps) {
tom7869ad92014-09-09 14:32:08 -0700211 checkNotNull(hostId, HOST_ID_NULL);
212 checkValidity();
Sahil Lele3a0cdd52015-07-21 14:16:31 -0700213 hostDescription = validateHost(hostDescription, hostId);
tom7869ad92014-09-09 14:32:08 -0700214 HostEvent event = store.createOrUpdateHost(provider().id(), hostId,
Brian O'Connorf107bd72015-09-21 15:31:03 -0700215 hostDescription, replaceIps);
tom7869ad92014-09-09 14:32:08 -0700216 if (event != null) {
tom7869ad92014-09-09 14:32:08 -0700217 post(event);
218 }
tomdb0d03f2014-08-27 16:34:15 -0700219 }
220
Sahil Lele3a0cdd52015-07-21 14:16:31 -0700221 // returns a HostDescription made from the union of the BasicHostConfig
222 // annotations if it exists
223 private HostDescription validateHost(HostDescription hostDescription, HostId hostId) {
224 BasicHostConfig cfg = networkConfigService.getConfig(hostId, BasicHostConfig.class);
225 checkState(cfg == null || cfg.isAllowed(), "Host {} is not allowed", hostId);
Ayaka Koshibe5373e762015-08-06 12:31:44 -0700226
227 return BasicHostOperator.combine(cfg, hostDescription);
Sahil Lele3a0cdd52015-07-21 14:16:31 -0700228 }
229
tomdb0d03f2014-08-27 16:34:15 -0700230 @Override
tom7869ad92014-09-09 14:32:08 -0700231 public void hostVanished(HostId hostId) {
232 checkNotNull(hostId, HOST_ID_NULL);
233 checkValidity();
234 HostEvent event = store.removeHost(hostId);
235 if (event != null) {
tom7869ad92014-09-09 14:32:08 -0700236 post(event);
237 }
tomdb0d03f2014-08-27 16:34:15 -0700238 }
samanwita palc40e5ed2015-09-24 11:01:51 -0700239
240 @Override
241 public void removeIpFromHost(HostId hostId, IpAddress ipAddress) {
242 checkNotNull(hostId, HOST_ID_NULL);
243 checkValidity();
244 HostEvent event = store.removeIp(hostId, ipAddress);
245 if (event != null) {
246 post(event);
247 }
248 }
tomdb0d03f2014-08-27 16:34:15 -0700249 }
tom7869ad92014-09-09 14:32:08 -0700250
tomc78acee2014-09-24 15:16:55 -0700251 // Store delegate to re-post events emitted from the store.
252 private class InternalStoreDelegate implements HostStoreDelegate {
253 @Override
254 public void notify(HostEvent event) {
255 post(event);
256 }
257 }
Sahil Lele3a0cdd52015-07-21 14:16:31 -0700258
259 // listens for NetworkConfigEvents of type BasicHostConfig and removes
260 // links that the config does not allow
261 private class InternalNetworkConfigListener implements NetworkConfigListener {
262 @Override
263 public void event(NetworkConfigEvent event) {
264 if ((event.type() == NetworkConfigEvent.Type.CONFIG_ADDED ||
265 event.type() == NetworkConfigEvent.Type.CONFIG_UPDATED) &&
266 event.configClass().equals(BasicHostConfig.class)) {
267 log.info("Detected Host network config event {}", event.type());
268 kickOutBadHost(((HostId) event.subject()));
269 }
270 }
271 }
272
273 // checks if the specified host is allowed by the BasicHostConfig
274 // and if not, removes it
275 private void kickOutBadHost(HostId hostId) {
276 BasicHostConfig cfg = networkConfigService.getConfig(hostId, BasicHostConfig.class);
277 if (cfg != null && !cfg.isAllowed()) {
278 Host badHost = getHost(hostId);
279 if (badHost != null) {
280 removeHost(hostId);
281 } else {
282 log.info("Failed removal: Host {} does not exist", hostId);
283 }
284 }
285 }
tomdb0d03f2014-08-27 16:34:15 -0700286}