145 lines
7.2 KiB
Markdown
145 lines
7.2 KiB
Markdown
# Renault Binding
|
|
|
|
This binding allows MyRenault App. users to get battery status and other data from their cars.
|
|
They can also heat their cars by turning ON the HVAC status and toggle the car's charging mode.
|
|
|
|
The binding translates the [python based renault-api](https://renault-api.readthedocs.io/en/latest/) in an easy to use openHAB java binding.
|
|
|
|
## Supported Things
|
|
|
|
Supports MyRenault registered cars with an active Connected-Services account.
|
|
|
|
This binding can only retrieve information that is available in the MyRenault App.
|
|
|
|
## Discovery
|
|
|
|
No discovery
|
|
|
|
## Thing Configuration
|
|
|
|
You require your MyRenault credential, locale and VIN for your MyRenault registered car.
|
|
|
|
| Parameter | Description | Default |
|
|
|-------------------|----------------------------------------------------------------------------|----------------------------------|
|
|
| myRenaultUsername | MyRenault Username. | |
|
|
| myRenaultPassword | MyRenault Password. | |
|
|
| locale | MyRenault Location (language_country). | |
|
|
| vin | Vehicle Identification Number. | |
|
|
| refreshInterval | Interval the car is polled in minutes. | 10 |
|
|
| updateDelay | How long to wait for commands to reach car and update to server in seconds.| 30 |
|
|
| kamereonApiKey | Kamereon API Key. | VAX7XYKGfa92yMvXculCkEFyfZbuM7Ss |
|
|
|
|
## Channels
|
|
|
|
| Channel ID | Type | Description | Read Only |
|
|
|------------------------|--------------------|-------------------------------------------------|-----------|
|
|
| batteryavailableEnergy | Number:Energy | Battery Energy Available | Yes |
|
|
| batterylevel | Number | State of the battery in % | Yes |
|
|
| batterystatusupdated | DateTime | Timestamp of the last battery status update | Yes |
|
|
| chargingmode | String | Charging mode. always_charging or schedule_mode | No |
|
|
| chargingstatus | String | Charging status | Yes |
|
|
| chargingremainingtime | Number:Time | Charging time remaining | Yes |
|
|
| plugstatus | String | Status of charging plug | Yes |
|
|
| estimatedrange | Number:Length | Estimated range of the car | Yes |
|
|
| odometer | Number:Length | Total distance travelled | Yes |
|
|
| hvacstatus | String | HVAC status HVAC Status (ON, OFF, PENDING) | No |
|
|
| hvactargettemperature | Number:Temperature | HVAC target temperature (19 to 21) | No |
|
|
| externaltemperature | Number:Temperature | Temperature outside of the car | Yes |
|
|
| image | String | Image URL of MyRenault | Yes |
|
|
| location | Location | The GPS position of the vehicle | Yes |
|
|
| locationupdated | DateTime | Timestamp of the last location update | Yes |
|
|
| locked | Switch | Locked status of the car | Yes |
|
|
|
|
## Limitations
|
|
|
|
Some channels may not work depending on your car and MyRenault account.
|
|
|
|
The "externaltemperature" only works on a few cars.
|
|
|
|
The "hvactargettemperature" is used by the hvacstatus ON command for pre-conditioning the car.
|
|
This seams to only allow values 19, 20 and 21 or else the pre-conditioning command will not work.
|
|
|
|
The Kamereon API Key changes periodically, which causes a communication error.
|
|
To fix this error update the API Key in the bindings configuration.
|
|
The new key value can hopefully be found in the renault-api project: [KAMEREON_APIKEY value](https://github.com/hacf-fr/renault-api/blob/main/src/renault_api/const.py) or in the openHAB forums.
|
|
|
|
## Example
|
|
|
|
renaultcar.sitemap:
|
|
|
|
```perl
|
|
sitemap renaultcar label="Renault Car" {
|
|
Frame {
|
|
Image item=RenaultCar_ImageURL
|
|
Default icon="batterylevel" item=RenaultCar_BatteryLevel
|
|
Default item=RenaultCar_BatteryEnergyAvailable
|
|
Default item=RenaultCar_BatteryStatusUpdated
|
|
Default icon="poweroutlet" item=RenaultCar_PlugStatus
|
|
Default icon="switch" item=RenaultCar_ChargingStatus
|
|
Selection icon="switch" item=RenaultCar_ChargingMode mappings=[SCHEDULE_MODE="Schedule mode",ALWAYS_CHARGING="Instant charge"]
|
|
Default item=RenaultCar_ChargingTimeRemaining
|
|
Default icon="pressure" item=RenaultCar_EstimatedRange
|
|
Default icon="pressure" item=RenaultCar_Odometer
|
|
Selection icon="switch" item=RenaultCar_HVACStatus mappings=[ON="ON"]
|
|
Setpoint icon="temperature" item=RenaultCar_HVACTargetTemperature maxValue=21 minValue=19 step=1
|
|
Default icon="lock" item=RenaultCar_Locked
|
|
Default item=RenaultCar_LocationUpdate
|
|
Default icon="zoom" item=RenaultCar_Location
|
|
}
|
|
}
|
|
```
|
|
|
|
If you want to limit the charge of the car battery to less than 100%, this can be done as follows.
|
|
|
|
- Set up an active dummy charge schedule in the MyRenault App.
|
|
|
|
- Create a Dimmer item "RenaultCar_ChargeLimit" and set it to 80% for example.
|
|
|
|
- Add the ChargeRenaultCarLimit rule using the code below.
|
|
|
|
The rule will change the RenaultCar_ChargingMode to schedule_mode when the limit is reached.
|
|
This stops charging after the battery level goes over the charge limit.
|
|
|
|
ChargeRenaultCarLimit Code
|
|
|
|
```javascript
|
|
configuration: {}
|
|
triggers:
|
|
- id: "1"
|
|
configuration:
|
|
itemName: RenaultCar_BatteryLevel
|
|
type: core.ItemStateUpdateTrigger
|
|
- id: "2"
|
|
configuration:
|
|
itemName: RenaultCar_ChargeLimit
|
|
type: core.ItemStateUpdateTrigger
|
|
- id: "3"
|
|
configuration:
|
|
itemName: RenaultCar_PlugStatus
|
|
type: core.ItemStateUpdateTrigger
|
|
conditions: []
|
|
actions:
|
|
- inputs: {}
|
|
id: "4"
|
|
configuration:
|
|
type: application/vnd.openhab.dsl.rule
|
|
script: >
|
|
if ( RenaultCar_PlugStatus.state.toString == 'PLUGGED' ) {
|
|
if ( RenaultCar_BatteryLevel.state as Number >= RenaultCar_ChargeLimit.state as Number ) {
|
|
if (RenaultCar_ChargingMode.state.toString != 'SCHEDULE_MODE' ) {
|
|
RenaultCar_ChargingMode.sendCommand("SCHEDULE_MODE")
|
|
}
|
|
} else {
|
|
if (RenaultCar_ChargingMode.state.toString != 'ALWAYS_CHARGING' ) {
|
|
RenaultCar_ChargingMode.sendCommand("ALWAYS_CHARGING")
|
|
}
|
|
}
|
|
} else {
|
|
if (RenaultCar_ChargingMode.state.toString != 'ALWAYS_CHARGING' ) {
|
|
RenaultCar_ChargingMode.sendCommand("ALWAYS_CHARGING")
|
|
}
|
|
}
|
|
type: script.ScriptAction
|
|
|
|
```
|