forked from openhab/openhab-addons
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
openhab#11465 Initial renualt-api binding Signed-off-by: Doug Culnane…
- Loading branch information
Culnane Douglas
committed
Oct 28, 2021
1 parent
7de37c6
commit 2218aab
Showing
14 changed files
with
1,037 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
This content is produced and maintained by the openHAB project. | ||
|
||
* Project home: https://www.openhab.org | ||
|
||
== Declared Project Licenses | ||
|
||
This program and the accompanying materials are made available under the terms | ||
of the Eclipse Public License 2.0 which is available at | ||
https://www.eclipse.org/legal/epl-2.0/. | ||
|
||
== Source Code | ||
|
||
https://github.com/openhab/openhab-addons |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
# Renault Binding | ||
|
||
This binding allow MyRenault App. users to get battery status and other data from their cars. | ||
|
||
A binding that translates the [python based renault-api](https://renault-api.readthedocs.io/en/latest/) in an easy to use binding. | ||
|
||
|
||
## Supported Things | ||
|
||
Works on my car (Renault Zoe 50) but I only have one car to test. | ||
|
||
|
||
## Discovery | ||
|
||
No discovery | ||
|
||
## Binding Configuration | ||
|
||
You require your MyRenault credential, locale and VIN for your MyRenault registered car. | ||
|
||
## Thing Configuration | ||
|
||
The thing has these configuration parameters: | ||
|
||
| Parameter | Description | Required | | ||
|-------------------|----------------------------------------|----------| | ||
| myRenaultUsername | MyRenault Username. | yes | | ||
| myRenaultPassword | MyRenault Password. | yes | | ||
| locale | MyRenault Location (language_country). | yes | | ||
| vin | Vehicle Identification Number. | yes | | ||
| refreshInterval | Interval the car is polled in minutes. | yes | | ||
|
||
## Channels | ||
|
||
Currently all available channels are read only: | ||
|
||
| Channel ID | Type | Description | | ||
|--------------|----------|---------------------------------| | ||
| batterylevel | Number | State of the battery in % | | ||
| hvacstatus | Switch | HVAC status switch | | ||
| image | String | Image URL of MyRenault | | ||
| location | Location | The GPS position of the vehicle | | ||
| odometer | Number | Total distance travelled | | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0" | ||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||
|
||
<modelVersion>4.0.0</modelVersion> | ||
|
||
<parent> | ||
<groupId>org.openhab.addons.bundles</groupId> | ||
<artifactId>org.openhab.addons.reactor.bundles</artifactId> | ||
<version>3.2.0-SNAPSHOT</version> | ||
</parent> | ||
|
||
<artifactId>org.openhab.binding.renault</artifactId> | ||
|
||
<name>openHAB Add-ons :: Bundles :: Renault Binding</name> | ||
|
||
</project> |
9 changes: 9 additions & 0 deletions
9
bundles/org.openhab.binding.renault/src/main/feature/feature.xml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<features name="org.openhab.binding.renault-${project.version}" xmlns="http://karaf.apache.org/xmlns/features/v1.4.0"> | ||
<repository>mvn:org.openhab.core.features.karaf/org.openhab.core.features.karaf.openhab-core/${ohc.version}/xml/features</repository> | ||
|
||
<feature name="openhab-binding-renault" description="Renault Binding" version="${project.version}"> | ||
<feature>openhab-runtime-base</feature> | ||
<bundle start-level="80">mvn:org.openhab.addons.bundles/org.openhab.binding.renault/${project.version}</bundle> | ||
</feature> | ||
</features> |
38 changes: 38 additions & 0 deletions
38
...g.renault/src/main/java/org/openhab/binding/renault/internal/RenaultBindingConstants.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
/** | ||
* Copyright (c) 2010-2021 Contributors to the openHAB project | ||
* | ||
* See the NOTICE file(s) distributed with this work for additional | ||
* information. | ||
* | ||
* This program and the accompanying materials are made available under the | ||
* terms of the Eclipse Public License 2.0 which is available at | ||
* http://www.eclipse.org/legal/epl-2.0 | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 | ||
*/ | ||
package org.openhab.binding.renault.internal; | ||
|
||
import org.eclipse.jdt.annotation.NonNullByDefault; | ||
import org.openhab.core.thing.ThingTypeUID; | ||
|
||
/** | ||
* The {@link RenaultBindingConstants} class defines common constants, which are | ||
* used across the whole binding. | ||
* | ||
* @author Doug Culnane - Initial contribution | ||
*/ | ||
@NonNullByDefault | ||
public class RenaultBindingConstants { | ||
|
||
private static final String BINDING_ID = "renault"; | ||
|
||
// List of all Thing Type UIDs | ||
public static final ThingTypeUID THING_TYPE_CAR = new ThingTypeUID(BINDING_ID, "car"); | ||
|
||
// List of all Channel ids | ||
public static final String CHANNEL_BATTERY_LEVEL = "batterylevel"; | ||
public static final String CHANNEL_HVAC_STATUS = "hvacstatus"; | ||
public static final String CHANNEL_IMAGE = "image"; | ||
public static final String CHANNEL_LOCATION = "location"; | ||
public static final String CHANNEL_ODOMETER = "odometer"; | ||
} |
27 changes: 27 additions & 0 deletions
27
...ding.renault/src/main/java/org/openhab/binding/renault/internal/RenaultConfiguration.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
/** | ||
* Copyright (c) 2010-2021 Contributors to the openHAB project | ||
* | ||
* See the NOTICE file(s) distributed with this work for additional | ||
* information. | ||
* | ||
* This program and the accompanying materials are made available under the | ||
* terms of the Eclipse Public License 2.0 which is available at | ||
* http://www.eclipse.org/legal/epl-2.0 | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 | ||
*/ | ||
package org.openhab.binding.renault.internal; | ||
|
||
/** | ||
* The {@link RenaultConfiguration} class contains fields mapping thing configuration parameters. | ||
* | ||
* @author Doug Culnane - Initial contribution | ||
*/ | ||
public class RenaultConfiguration { | ||
|
||
public String myRenaultUsername; | ||
public String myRenaultPassword; | ||
public String locale; | ||
public String vin; | ||
public int refreshInterval; | ||
} |
103 changes: 103 additions & 0 deletions
103
...ab.binding.renault/src/main/java/org/openhab/binding/renault/internal/RenaultHandler.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,103 @@ | ||
/** | ||
* Copyright (c) 2010-2021 Contributors to the openHAB project | ||
* | ||
* See the NOTICE file(s) distributed with this work for additional | ||
* information. | ||
* | ||
* This program and the accompanying materials are made available under the | ||
* terms of the Eclipse Public License 2.0 which is available at | ||
* http://www.eclipse.org/legal/epl-2.0 | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 | ||
*/ | ||
package org.openhab.binding.renault.internal; | ||
|
||
import static org.openhab.binding.renault.internal.RenaultBindingConstants.*; | ||
|
||
import java.util.concurrent.ScheduledFuture; | ||
import java.util.concurrent.TimeUnit; | ||
|
||
import org.eclipse.jdt.annotation.NonNullByDefault; | ||
import org.eclipse.jdt.annotation.Nullable; | ||
import org.openhab.binding.renault.internal.renault.api.Car; | ||
import org.openhab.binding.renault.internal.renault.api.MyRenaultHttpSession; | ||
import org.openhab.core.library.types.DecimalType; | ||
import org.openhab.core.library.types.OnOffType; | ||
import org.openhab.core.library.types.PointType; | ||
import org.openhab.core.library.types.StringType; | ||
import org.openhab.core.thing.ChannelUID; | ||
import org.openhab.core.thing.Thing; | ||
import org.openhab.core.thing.ThingStatus; | ||
import org.openhab.core.thing.ThingStatusDetail; | ||
import org.openhab.core.thing.binding.BaseThingHandler; | ||
import org.openhab.core.types.Command; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
|
||
/** | ||
* The {@link RenaultHandler} is responsible for handling commands, which are | ||
* sent to one of the channels. | ||
* | ||
* @author Doug Culnane - Initial contribution | ||
*/ | ||
@NonNullByDefault | ||
public class RenaultHandler extends BaseThingHandler { | ||
|
||
private final Logger logger = LoggerFactory.getLogger(RenaultHandler.class); | ||
|
||
private @Nullable RenaultConfiguration config; | ||
|
||
private @Nullable ScheduledFuture<?> pollingJob; | ||
|
||
public RenaultHandler(Thing thing) { | ||
super(thing); | ||
} | ||
|
||
@Override | ||
public void handleCommand(ChannelUID channelUID, Command command) { | ||
// This binding only polls status data automatically. | ||
} | ||
|
||
@Override | ||
public void initialize() { | ||
updateStatus(ThingStatus.UNKNOWN); | ||
this.config = getConfigAs(RenaultConfiguration.class); | ||
|
||
// Background initialization: | ||
if (pollingJob == null || pollingJob.isCancelled()) { | ||
pollingJob = scheduler.scheduleWithFixedDelay(this::getStatus, 0, config.refreshInterval, TimeUnit.MINUTES); | ||
} | ||
} | ||
|
||
@Override | ||
public void dispose() { | ||
if (pollingJob != null) { | ||
pollingJob.cancel(true); | ||
pollingJob = null; | ||
} | ||
super.dispose(); | ||
} | ||
|
||
private void getStatus() { | ||
MyRenaultHttpSession httpSession; | ||
try { | ||
httpSession = new MyRenaultHttpSession(this.config); | ||
updateStatus(ThingStatus.ONLINE, ThingStatusDetail.NONE); | ||
httpSession.updateCarData(this.config); | ||
updateState(httpSession.getCar()); | ||
} catch (Exception e) { | ||
httpSession = null; | ||
logger.error("Error My Renault Http Session.", e); | ||
updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.COMMUNICATION_ERROR, e.getMessage()); | ||
} | ||
} | ||
|
||
private void updateState(Car car) { | ||
updateState(CHANNEL_BATTERY_LEVEL, new DecimalType(car.batteryLevel)); | ||
updateState(CHANNEL_HVAC_STATUS, (car.hvacstatus ? OnOffType.ON : OnOffType.OFF)); | ||
updateState(CHANNEL_IMAGE, new StringType(car.imageURL)); | ||
updateState(CHANNEL_LOCATION, | ||
new PointType(new DecimalType(car.gpsLatitude), new DecimalType(car.gpsLongitude))); | ||
updateState(CHANNEL_ODOMETER, new DecimalType(car.odometer)); | ||
} | ||
} |
60 changes: 60 additions & 0 deletions
60
...ing.renault/src/main/java/org/openhab/binding/renault/internal/RenaultHandlerFactory.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
/** | ||
* Copyright (c) 2010-2021 Contributors to the openHAB project | ||
* | ||
* See the NOTICE file(s) distributed with this work for additional | ||
* information. | ||
* | ||
* This program and the accompanying materials are made available under the | ||
* terms of the Eclipse Public License 2.0 which is available at | ||
* http://www.eclipse.org/legal/epl-2.0 | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 | ||
*/ | ||
package org.openhab.binding.renault.internal; | ||
|
||
import static org.openhab.binding.renault.internal.RenaultBindingConstants.*; | ||
|
||
import java.util.Set; | ||
|
||
import org.eclipse.jdt.annotation.NonNullByDefault; | ||
import org.eclipse.jdt.annotation.Nullable; | ||
import org.openhab.core.thing.Thing; | ||
import org.openhab.core.thing.ThingTypeUID; | ||
import org.openhab.core.thing.binding.BaseThingHandlerFactory; | ||
import org.openhab.core.thing.binding.ThingHandler; | ||
import org.openhab.core.thing.binding.ThingHandlerFactory; | ||
import org.osgi.service.component.annotations.Activate; | ||
import org.osgi.service.component.annotations.Component; | ||
|
||
/** | ||
* The {@link RenaultHandlerFactory} is responsible for creating things and thing | ||
* handlers. | ||
* | ||
* @author Doug Culnane - Initial contribution | ||
*/ | ||
@NonNullByDefault | ||
@Component(configurationPid = "binding.renault", service = ThingHandlerFactory.class) | ||
public class RenaultHandlerFactory extends BaseThingHandlerFactory { | ||
|
||
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_CAR); | ||
|
||
@Activate | ||
public RenaultHandlerFactory() { | ||
} | ||
|
||
@Override | ||
public boolean supportsThingType(ThingTypeUID thingTypeUID) { | ||
return SUPPORTED_THING_TYPES_UIDS.contains(thingTypeUID); | ||
} | ||
|
||
@Override | ||
protected @Nullable ThingHandler createHandler(Thing thing) { | ||
ThingTypeUID thingTypeUID = thing.getThingTypeUID(); | ||
|
||
if (THING_TYPE_CAR.equals(thingTypeUID)) { | ||
return new RenaultHandler(thing); | ||
} | ||
|
||
return null; | ||
} | ||
} |
Oops, something went wrong.