2 * Copyright (c) 2010-2020 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
7 * This program and the accompanying materials are made available under the
8 * terms of the Eclipse Public License 2.0 which is available at
9 * http://www.eclipse.org/legal/epl-2.0
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.binding.tesla.internal.discovery;
17 import org.eclipse.jdt.annotation.NonNull;
18 import org.eclipse.jdt.annotation.Nullable;
19 import org.openhab.binding.tesla.internal.TeslaBindingConstants;
20 import org.openhab.binding.tesla.internal.TeslaHandlerFactory;
21 import org.openhab.binding.tesla.internal.handler.TeslaAccountHandler;
22 import org.openhab.binding.tesla.internal.handler.VehicleListener;
23 import org.openhab.binding.tesla.internal.protocol.Vehicle;
24 import org.openhab.binding.tesla.internal.protocol.VehicleConfig;
25 import org.openhab.core.config.discovery.AbstractDiscoveryService;
26 import org.openhab.core.config.discovery.DiscoveryResult;
27 import org.openhab.core.config.discovery.DiscoveryResultBuilder;
28 import org.openhab.core.config.discovery.DiscoveryService;
29 import org.openhab.core.thing.ThingTypeUID;
30 import org.openhab.core.thing.ThingUID;
31 import org.openhab.core.thing.binding.ThingHandler;
32 import org.openhab.core.thing.binding.ThingHandlerService;
33 import org.osgi.service.component.annotations.Component;
34 import org.slf4j.Logger;
35 import org.slf4j.LoggerFactory;
38 * This service is used by {@link TeslaAccountHandler} instances in order to
39 * automatically provide vehicle information from the account.
41 * @author Kai Kreuzer - Initial contribution
44 @Component(service = ThingHandlerService.class)
45 public class TeslaVehicleDiscoveryService extends AbstractDiscoveryService
46 implements DiscoveryService, VehicleListener, ThingHandlerService {
47 private final Logger logger = LoggerFactory.getLogger(TeslaVehicleDiscoveryService.class);
49 public TeslaVehicleDiscoveryService() throws IllegalArgumentException {
50 super(TeslaHandlerFactory.SUPPORTED_THING_TYPES_UIDS, 10, true);
53 private TeslaAccountHandler handler;
56 public void setThingHandler(ThingHandler handler) {
57 this.handler = (TeslaAccountHandler) handler;
58 this.handler.addVehicleListener(this);
62 public ThingHandler getThingHandler() {
67 protected void startScan() {
68 handler.scanForVehicles();
72 public void activate(@Nullable Map<@NonNull String, @Nullable Object> configProperties) {
73 super.activate(configProperties);
77 public void deactivate() {
79 if (handler != null) {
80 handler.removeVehicleListener(this);
85 public void vehicleFound(Vehicle vehicle, VehicleConfig vehicleConfig) {
86 ThingTypeUID type = identifyModel(vehicleConfig);
88 ThingUID thingUID = new ThingUID(type, handler.getThing().getUID(), vehicle.vin);
89 DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID).withLabel(vehicle.display_name)
90 .withBridge(handler.getThing().getUID()).withProperty(TeslaBindingConstants.VIN, vehicle.vin)
92 thingDiscovered(discoveryResult);
96 private ThingTypeUID identifyModel(VehicleConfig vehicleConfig) {
97 logger.debug("Found a {} vehicle", vehicleConfig.car_type);
98 switch (vehicleConfig.car_type) {
101 return TeslaBindingConstants.THING_TYPE_MODELS;
103 return TeslaBindingConstants.THING_TYPE_MODELX;
105 return TeslaBindingConstants.THING_TYPE_MODEL3;
107 return TeslaBindingConstants.THING_TYPE_MODELY;
109 logger.debug("Found unknown vehicle type '{}' - ignoring it.", vehicleConfig.car_type);