blob: 47d4f91a8ad5e3a7384ebab55eda54a5998e56f2 [file] [log] [blame]
alshabib77b88482015-04-07 15:47:50 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2015-present Open Networking Foundation
alshabib77b88482015-04-07 15:47:50 -07003 *
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 */
16package org.onosproject.net.driver.impl;
17
alshabib77b88482015-04-07 15:47:50 -070018import org.apache.felix.scr.annotations.Activate;
19import org.apache.felix.scr.annotations.Component;
20import org.apache.felix.scr.annotations.Deactivate;
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070021import org.apache.felix.scr.annotations.Reference;
22import org.apache.felix.scr.annotations.ReferenceCardinality;
alshabib77b88482015-04-07 15:47:50 -070023import org.apache.felix.scr.annotations.Service;
HIGUCHI Yuta11d16092015-12-04 23:35:43 -080024import org.onlab.util.ItemNotFoundException;
Thomas Vachuska3afbc7f2016-02-01 15:55:38 -080025import org.onosproject.net.AbstractProjectableModel;
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070026import org.onosproject.net.Device;
alshabib77b88482015-04-07 15:47:50 -070027import org.onosproject.net.DeviceId;
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070028import org.onosproject.net.device.DeviceService;
alshabib77b88482015-04-07 15:47:50 -070029import org.onosproject.net.driver.Behaviour;
30import org.onosproject.net.driver.DefaultDriverData;
31import org.onosproject.net.driver.DefaultDriverHandler;
32import org.onosproject.net.driver.Driver;
alshabib77b88482015-04-07 15:47:50 -070033import org.onosproject.net.driver.DriverHandler;
Thomas Vachuskae6a57412017-08-23 14:09:14 -070034import org.onosproject.net.driver.DriverListener;
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070035import org.onosproject.net.driver.DriverRegistry;
36import org.onosproject.net.driver.DriverService;
alshabib77b88482015-04-07 15:47:50 -070037import org.slf4j.Logger;
38import org.slf4j.LoggerFactory;
39
alshabib77b88482015-04-07 15:47:50 -070040import java.util.Set;
Thomas Vachuska5c2f8132015-04-08 23:09:08 -070041import java.util.stream.Collectors;
alshabib77b88482015-04-07 15:47:50 -070042
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070043import static org.onlab.util.Tools.nullIsNotFound;
44import static org.onosproject.net.AnnotationKeys.DRIVER;
Changhoon Yoon541ef712015-05-23 17:18:34 +090045import static org.onosproject.security.AppGuard.checkPermission;
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070046import static org.onosproject.security.AppPermission.Type.DRIVER_READ;
47import static org.onosproject.security.AppPermission.Type.DRIVER_WRITE;
alshabib77b88482015-04-07 15:47:50 -070048
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070049/**
50 * Manages inventory of device drivers.
51 */
alshabib77b88482015-04-07 15:47:50 -070052@Service
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070053// Not enabled by default to allow the DriverRegistryManager to enable it only
54// when all the required drivers are available.
55@Component(immediate = true, enabled = false)
56public class DriverManager implements DriverService {
alshabib77b88482015-04-07 15:47:50 -070057
58 private final Logger log = LoggerFactory.getLogger(getClass());
59
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070060 private static final String NO_DRIVER = "Driver not found";
61 private static final String NO_DEVICE = "Device not found";
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070062
63 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
64 protected DriverRegistry registry;
Thomas Vachuskaca88bb72015-04-08 19:38:02 -070065
66 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
67 protected DeviceService deviceService;
68
alshabib77b88482015-04-07 15:47:50 -070069 @Activate
70 protected void activate() {
Thomas Vachuska3afbc7f2016-02-01 15:55:38 -080071 AbstractProjectableModel.setDriverService(null, this);
alshabib77b88482015-04-07 15:47:50 -070072 log.info("Started");
73 }
74
75 @Deactivate
76 protected void deactivate() {
Thomas Vachuska3afbc7f2016-02-01 15:55:38 -080077 AbstractProjectableModel.setDriverService(this, null);
alshabib77b88482015-04-07 15:47:50 -070078 log.info("Stopped");
79 }
80
alshabib77b88482015-04-07 15:47:50 -070081 @Override
Thomas Vachuska5c2f8132015-04-08 23:09:08 -070082 public Set<Driver> getDrivers() {
Changhoon Yoonb856b812015-08-10 03:47:19 +090083 checkPermission(DRIVER_READ);
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070084 return registry.getDrivers();
alshabib77b88482015-04-07 15:47:50 -070085 }
86
87 @Override
Thomas Vachuska5c2f8132015-04-08 23:09:08 -070088 public Set<Driver> getDrivers(Class<? extends Behaviour> withBehaviour) {
Changhoon Yoonb856b812015-08-10 03:47:19 +090089 checkPermission(DRIVER_READ);
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070090 return registry.getDrivers().stream()
Thomas Vachuska5c2f8132015-04-08 23:09:08 -070091 .filter(d -> d.hasBehaviour(withBehaviour))
92 .collect(Collectors.toSet());
93 }
94
95 @Override
alshabib77b88482015-04-07 15:47:50 -070096 public Driver getDriver(String driverName) {
Changhoon Yoonb856b812015-08-10 03:47:19 +090097 checkPermission(DRIVER_READ);
Thomas Vachuska11b99fc2017-04-27 12:51:04 -070098 return registry.getDriver(driverName);
alshabib77b88482015-04-07 15:47:50 -070099 }
100
101 @Override
102 public Driver getDriver(String mfr, String hw, String sw) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900103 checkPermission(DRIVER_READ);
Thomas Vachuska11b99fc2017-04-27 12:51:04 -0700104 return registry.getDriver(mfr, hw, sw);
alshabib77b88482015-04-07 15:47:50 -0700105 }
106
107 @Override
Thomas Vachuskaca88bb72015-04-08 19:38:02 -0700108 public Driver getDriver(DeviceId deviceId) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900109 checkPermission(DRIVER_READ);
Changhoon Yoon541ef712015-05-23 17:18:34 +0900110
Thomas Vachuskaca88bb72015-04-08 19:38:02 -0700111 Device device = nullIsNotFound(deviceService.getDevice(deviceId), NO_DEVICE);
112 String driverName = device.annotations().value(DRIVER);
113 if (driverName != null) {
HIGUCHI Yuta11d16092015-12-04 23:35:43 -0800114 try {
115 return getDriver(driverName);
116 } catch (ItemNotFoundException e) {
117 log.warn("Specified driver {} not found, falling back.", driverName);
118 }
Thomas Vachuskaca88bb72015-04-08 19:38:02 -0700119 }
HIGUCHI Yuta11d16092015-12-04 23:35:43 -0800120
Thomas Vachuskaca88bb72015-04-08 19:38:02 -0700121 return nullIsNotFound(getDriver(device.manufacturer(),
122 device.hwVersion(), device.swVersion()),
123 NO_DRIVER);
124 }
125
126 @Override
127 public DriverHandler createHandler(DeviceId deviceId, String... credentials) {
Changhoon Yoonb856b812015-08-10 03:47:19 +0900128 checkPermission(DRIVER_WRITE);
Thomas Vachuskaca88bb72015-04-08 19:38:02 -0700129 Driver driver = getDriver(deviceId);
Thomas Vachuska80b0a802015-07-17 08:43:30 -0700130 return new DefaultDriverHandler(new DefaultDriverData(driver, deviceId));
alshabib77b88482015-04-07 15:47:50 -0700131 }
132
Thomas Vachuskae6a57412017-08-23 14:09:14 -0700133 @Override
134 public void addListener(DriverListener listener) {
135 registry.addListener(listener);
136 }
137
138 @Override
139 public void removeListener(DriverListener listener) {
140 registry.removeListener(listener);
141 }
alshabib77b88482015-04-07 15:47:50 -0700142}