diff --git a/CODEOWNERS b/CODEOWNERS index 51771a55b..ee0088abd 100644 --- a/CODEOWNERS +++ b/CODEOWNERS @@ -43,7 +43,6 @@ /bundles/org.openhab.binding.bluetooth.govee/ @cpmeister /bundles/org.openhab.binding.bluetooth.roaming/ @cpmeister /bundles/org.openhab.binding.bluetooth.ruuvitag/ @ssalonen -/bundles/org.openhab.binding.bmwconnecteddrive/ @weymann @ntruchsess /bundles/org.openhab.binding.boschindego/ @jofleck /bundles/org.openhab.binding.boschshc/ @stefan-kaestle @coeing @GerdZanker /bundles/org.openhab.binding.bosesoundtouch/ @marvkis @tratho diff --git a/bom/openhab-addons/pom.xml b/bom/openhab-addons/pom.xml index 2a983e6dc..87c62166d 100644 --- a/bom/openhab-addons/pom.xml +++ b/bom/openhab-addons/pom.xml @@ -206,11 +206,6 @@ org.openhab.binding.bluetooth.ruuvitag ${project.version} - - org.openhab.addons.bundles - org.openhab.binding.bmwconnecteddrive - ${project.version} - org.openhab.addons.bundles org.openhab.binding.boschindego diff --git a/bundles/org.openhab.binding.bmwconnecteddrive/NOTICE b/bundles/org.openhab.binding.bmwconnecteddrive/NOTICE deleted file mode 100644 index 38d625e34..000000000 --- a/bundles/org.openhab.binding.bmwconnecteddrive/NOTICE +++ /dev/null @@ -1,13 +0,0 @@ -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 diff --git a/bundles/org.openhab.binding.bmwconnecteddrive/README.md b/bundles/org.openhab.binding.bmwconnecteddrive/README.md deleted file mode 100644 index 8036f5618..000000000 --- a/bundles/org.openhab.binding.bmwconnecteddrive/README.md +++ /dev/null @@ -1,998 +0,0 @@ -# BMW ConnectedDrive Binding - -The binding provides a connection between [BMW's ConnectedDrive Portal](https://www.bmw-connecteddrive.com/country-region-select/country-region-selection.html) and openHAB. -All vehicles connected to an account will be detected by the discovery with the correct type - -* Conventional Fuel Vehicle -* Plugin-Hybrid Electrical Vehicle -* Battery Electric Vehicle with Range Extender -* Battery Electric Vehicle - -In addition properties are attached with information and services provided by this vehicle. -The provided data depends on - -1. the [Thing Type](#things) and -2. the [Properties](#properties) mentioned in Services - -Different channel groups are clustering all informations. -Check for each group if it's supported for this Vehicle. - -Please note **this isn't a real-time binding**. -If a door is opened the state isn't transmitted and changed immediately. -This isn't a flaw in the binding itself because the state in BMW's own ConnectedDrive App is also updated with some delay. - -## Supported Things - -### Bridge - -The bridge establishes the connection between BMW's ConnectedDrive Portal and openHAB. - -| Name | Bridge Type ID | Description | -|----------------------------|----------------|------------------------------------------------------------| -| BMW ConnectedDrive Account | `account` | Access to BMW ConnectedDrive Portal for a specific user | - - -### Things - -Four different vehicle types are provided. -They differ in the supported channel groups & channels. -Conventional Fuel Vehicles have no _Charging Profile_, Electric Vehicles don't provide a _Fuel Range_. -For hybrid vehicles in addition to _Fuel and Electric Range_ the _Hybrid Range_ is shown. - -| Name | Thing Type ID | Supported Channel Groups | -|-------------------------------------|---------------|--------------------------------------------------------| -| BMW Electric Vehicle | `bev` | status, range, location, service, check, charge, image | -| BMW Electric Vehicle with REX | `bev_rex` | status, range, location, service, check, charge, image | -| BMW Plug-In-Hybrid Electric Vehicle | `phev` | status, range, location, service, check, charge, image | -| BMW Conventional Vehicle | `conv` | status, range, location, service, check, image | - - -#### Properties - - - -For each vehicle properties are available. -Basically 3 types of information are registered as properties - -* Informations regarding your dealer with address and phone number -* Which services are available / not available -* Vehicle properties like color, model type, drive train and construction year - -In the right picture can see in *Services Activated* e.g. the *DoorLock* and *DoorUnlock* services are mentioned. -This ensures channel group [Remote Services](#remote-services) is supporting door lock and unlock remote control. - -In *Services Supported* the entry *LastDestination* is mentioned. -So it's valid to connect channel group [Last Destinations](#destinations) in order to display and select the last navigation destinations. - -| Property Key | Property Value | Supported Channel Groups | -|--------------------|---------------------|------------------------------| -| servicesSupported | Statistics | last-trip, lifetime | -| servicesSupported | LastDestinations | destinations | -| servicesActivated | _list of services_ | remote | - - -## Discovery - -Auto discovery is starting after the bridge towards BMW's ConnectedDrive is created. -A list of your registered vehicles is queried and all found things are added in the inbox. -Unique identifier is the *Vehicle Identification Number* (VIN). -If a thing is already declared in a _.things_ configuration, discovery won't highlight it again. -Properties will be attached to predefined vehicles if the VIN is matching. - -## Configuration - -### Bridge Configuration - -| Parameter | Type | Description | -|-----------------|---------|--------------------------------------------------------------------| -| userName | text | BMW ConnectedDrive Username | -| password | text | BMW ConnectedDrive Password | -| region | text | Select region in order to connect to the appropriate BMW server. | - -The region Configuration has 3 different options - -* _NORTH_AMERICA_ -* _CHINA_ -* _ROW_ (Rest of World) - - -#### Advanced Configuration - -| Parameter | Type | Description | -|-----------------|---------|--------------------------------------------------------------------| -| preferMyBmw | boolean | Prefer *MyBMW* API instead of *BMW Connected Drive* | - - -### Thing Configuration - -Same configuration is needed for all things - -| Parameter | Type | Description | -|-----------------|---------|---------------------------------------| -| vin | text | Vehicle Identification Number (VIN) | -| refreshInterval | integer | Refresh Interval in Minutes | -| units | text | Unit Selection. See below. | -| imageSize | integer | Image Size | -| imageViewport | text | Image Viewport | - -The unit configuration has 3 options - -* _AUTODETECT_ selects miles for US & UK, kilometer otherwise -* _METRIC_ selects directly kilometers -* _IMPERIAL_ selects directly miles - -The _imageVieport_ allows to show the vehicle from different angels. -Possible options are - -* _FRONT_ -* _REAR_ -* _SIDE_ -* _DASHBOARD_ -* _DRIVERDOOR_ - -## Channels - -There are many channels available for each vehicle. -For better overview they are clustered in different channel groups. -They differ for each vehicle type, build-in sensors and activated services. - - -### Thing Channel Groups - -#### Vehicle Status - -Reflects overall status of the vehicle. - -* Channel Group ID is **status** -* Available for all vehicles -* Read-only values - -| Channel Label | Channel ID | Type | Description | -|---------------------------|---------------------|---------------|------------------------------------------------| -| Overall Door Status | doors | String | Combined status for all doors | -| Overall Window Status | windows | String | Combined status for all windows | -| Doors Locked | lock | String | Status if doors are locked or unlocked | -| Next Service Date | service-date | DateTime | Date of upcoming service | -| Mileage till Next Service | service-mileage | Number:Length | Mileage till upcoming service | -| Check Control | check-control | String | Presence of active warning messages | -| Plug Connection Status | plug-connection | String | Only available for phev, bev_rex and bev | -| Charging Status | charge | String | Only available for phev, bev_rex and bev | -| Last Status Timestamp | last-update | DateTime | Date and time of last status update | -| Last Status Update Reason | last-update-reason | DateTime | Date and time of last status update | - -Overall Door Status values - -* _Closed_ - all doors closed -* _Open_ - at least one door is open -* _Undef_ - no door data delivered at all - -Overall Windows Status values - -* _Closed_ - all windows closed -* _Open_ - at least one window is completely open -* _Intermediate_ - at least one window is partially open -* _Undef_ - no window data delivered at all - -Check Control values - -* _Active_ - at least one warning message is active -* _Not Active_ - no warning message is active -* _Undef_ - no data for warnings delivered - -Charging Status values - -* _Charging_ -* _Error_ -* _Finished Fully Charged_ -* _Finished Not Full_ -* _Invalid_ -* _Not Charging_ -* _Charging Goal reached_ -* _Waiting For Charging_ - -Last update reasons - -* _CHARGING_DONE_ -* _CHARGING_INTERRUPED_ -* _CHARGING_PAUSED -* _CHARGING_STARTED_ -* _CYCLIC_RECHARGING_ -* _DISCONNECTED_ -* _DOOR_STATE_CHANGED_ -* _NO_CYCLIC_RECHARGING_ -* _NO_LSC_TRIGGER_ -* _ON_DEMAND_ -* _PREDICTION_UPDATE_ -* _TEMPORARY_POWER_SUPPLY_FAILURE_ -* _UNKNOWN_ -* _VEHICLE_MOVING_ -* _VEHICLE_SECURED_ -* _VEHICLE_SHUTDOWN_ -* _VEHICLE_SHUTDOWN_SECURED_ -* _VEHICLE_UNSECURED_ - -#### Services - -Group for all upcoming services with description, service date and/or service mileage. -If more than one service is scheduled in the future the channel _name_ contains all future services as options. - -* Channel Group ID is **service** -* Available for all vehicles -* Read/Write access - -| Channel Label | Channel ID | Type | Access | -|--------------------------------|---------------------|----------------|------------| -| Service Name | name | String | Read/Write | -| Service Details | details | String | Read | -| Service Date | date | Number | Read | -| Mileage till Service | mileage | Number:Length | Read | - -#### Check Control - -Group for all current active CheckControl messages. -If more than one message is active the channel _name_ contains all active messages as options. - -* Channel Group ID is **check** -* Available for all vehicles -* Read/Write access - -| Channel Label | Channel ID | Type | Access | -|---------------------------------|---------------------|----------------|------------| -| CheckControl Description | name | String | Read/Write | -| CheckControl Details | details | String | Read | -| Mileage Occurrence | mileage | Number:Length | Read | - -#### Doors Details - -Detailed status of all doors and windows. - -* Channel Group ID is **doors** -* Available for all vehicles if corresponding sensors are built-in -* Read-only values - -| Channel Label | Channel ID | Type | -|----------------------------|-------------------------|---------------| -| Driver Door | driver-front | String | -| Driver Door Rear | driver-rear | String | -| Passenger Door | passenger-front | String | -| Passenger Door Rear | passenger-rear | String | -| Trunk | trunk | String | -| Hood | hood | String | -| Driver Window | win-driver-front | String | -| Driver Rear Window | win-driver-rear | String | -| Passenger Window | win-passenger-front | String | -| Passenger Rear Window | win-passenger-rear | String | -| Rear Window | win-rear | String | -| Sunroof | sunroof | String | - -Possible states - -* _Undef_ - no status data available -* _Invalid_ - this door / window isn't applicable for this vehicle -* _Closed_ - the door / window is closed -* _Open_ - the door / window is open -* _Intermediate_ - window in intermediate position, not applicable for doors - -#### Range Data - -Based on vehicle type some channels are present or not. -Conventional fuel vehicles don't provide *Electric Range* and battery electric vehicles don't show *Fuel Range*. -Hybrid vehicles have both and in addition *Hybrid Range*. -See description [Range vs Range Radius](#range-vs-range-radius) to get more information. - -* Channel Group ID is **range** -* Availability according to table -* Read-only values - -| Channel Label | Channel ID | Type | conv | phev | bev_rex | bev | -|---------------------------|-------------------------|----------------------|------|------|---------|-----| -| Mileage | mileage | Number:Length | X | X | X | X | -| Fuel Range | range-fuel | Number:Length | X | X | X | | -| Battery Range | range-electric | Number:Length | | X | X | X | -| Max Battery Range | range-electric-max | Number:Length | | X | X | X | -| Hybrid Range | range-hybrid | Number:Length | | X | X | | -| Battery Charge Level | soc | Number:Dimensionless | | X | X | X | -| Max Battery Capacity | soc-max | Number:Power | | | X | X | X | -| Remaining Fuel | remaining-fuel | Number:Volume | X | X | X | | -| Fuel Range Radius | range-radius-fuel | Number:Length | X | X | X | | -| Electric Range Radius | range-radius-electric | Number:Length | | X | X | X | -| Hybrid Range Radius | range-radius-hybrid | Number:Length | | X | X | | -| Max Hybrid Range Radius | range-radius-hybrid-max | Number:Length | | X | X | | - - -#### Charge Profile - -Charging options with date and time for preferred time windows and charging modes. - -* Channel Group ID is **charge** -* Available for electric and hybrid vehicles -* Read/Write access for UI. Use [Charge Profile Editing Action](#charge-profile-editing) in rules -* There are 3 timers *T1, T2 and T3* available. Replace *X* with number 1,2 or 3 to target the correct timer -* Additional override Timer *OT* defines a single departure besides the 3 predefined schedule timers - -| Channel Label | Channel Group ID | Channel ID | Type | -|----------------------------|------------------|---------------------------|----------| -| Charge Mode | charge | profile-mode | String | -| Charge Preferences | charge | profile-prefs | String | -| Window Start Time | charge | window-start | DateTime | -| Window End Time | charge | window-end | DateTime | -| A/C at Departure | charge | profile-climate | Switch | -| T*X* Enabled | charge | timer*X*-enabled | Switch | -| T*X* Departure Time | charge | timer*X*-departure | DateTime | -| T*X* Days | charge | timer*X*-days | String | -| T*X* Monday | charge | timer*X*-day-mon | Switch | -| T*X* Tuesday | charge | timer*X*-day-tue | Switch | -| T*X* Wednesday | charge | timer*X*-day-wed | Switch | -| T*X* Thursday | charge | timer*X*-day-thu | Switch | -| T*X* Friday | charge | timer*X*-day-fri | Switch | -| T*X* Saturday | charge | timer*X*-day-sat | Switch | -| T*X* Sunday | charge | timer*X*-day-sun | Switch | -| OT Enabled | charge | override-enabled | Switch | -| OT Departure Time | charge | override-departure | DateTime | - -The channel _profile-mode_ supports - -* *IMMEDIATE_CHARGING* -* *DELAYED_CHARGING* - -The channel _profile-prefs_ supports - -* *NO_PRESELECTION* -* *CHARGING_WINDOW* - -#### Location - -GPS location and heading of the vehicle. - -* Channel Group ID is **location** -* Available for all vehicles with built-in GPS sensor. Function can be enabled/disabled in the head unit -* Read-only values - -| Channel Label | Channel ID | Type | -|-----------------|---------------------|--------------| -| GPS Coordinates | gps | Location | -| Heading | heading | Number:Angle | - -#### Last Trip - -Statistic values of duration, distance and consumption of the last trip. - -* Channel Group ID is **last-trip** -* Available if *Statistics* is present in *Services Supported*. See [Vehicle Properties](#properties) for further details -* Read-only values -* Depending on units configuration in [Thing Configuration](#thing-configuration) average values are given for 100 kilometers or miles - -| Channel Label | Channel ID | Type | -|-----------------------------------------|------------------------------|---------------| -| Last Trip Date | date | DateTime | -| Last Trip Duration | duration | Number:Time | -| Last Trip Distance | distance | Number:Length | -| Distance since Charge | distance-since-charging | Number:Length | -| Avg. Power Consumption | avg-consumption | Number:Power | -| Avg. Power Recuperation | avg-recuperation | Number:Power | -| Avg. Combined Consumption | avg-combined-consumption | Number:Volume | - - -#### Lifetime Statistics - -Providing lifetime consumption values. - -* Channel Group ID is **lifetime** -* Available if *Statistics* is present in *Services Supported*. See [Vehicle Properties](#properties) for further details -* Read-only values -* Depending on units configuration in [Thing Configuration](#thing-configuration) average values are given for 100 kilometers or miles - -| Channel Label | Channel ID | Type | -|-----------------------------------------|------------------------------|---------------| -| Total Electric Distance | total-driven-distance | Number:Length | -| Longest 1-Charge Distance | single-longest-distance | Number:Length | -| Avg. Power Consumption | avg-consumption | Number:Power | -| Avg. Power Recuperation | avg-recuperation | Number:Power | -| Avg. Combined Consumption | avg-combined-consumption | Number:Volume | - - -#### Remote Services - -Remote control of the vehicle. -Send a *command* to the vehicle and the *state* is reporting the execution progress. -Only one command can be executed each time. -Parallel execution isn't supported. - -* Channel Group ID is **remote** -* Available for all commands mentioned in *Services Activated*. See [Vehicle Properties](#properties) for further details -* Read/Write access - - -| Channel Label | Channel ID | Type | Access | -|-------------------------|---------------------|---------|--------| -| Remote Service Command | command | String | Write | -| Service Execution State | state | String | Read | - -The channel _command_ provides options - -* _Flash Lights_ -* _Vehicle Finder_ -* _Door Lock_ -* _Door Unlock_ -* _Horn Blow_ -* _Climate Control_ -* _Start Charging_ -* _Send Charging Profile_ - -The channel _state_ shows the progress of the command execution in the following order - -1) _Initiated_ -2) _Pending_ -3) _Delivered_ -4) _Executed_ - -#### Destinations - -Shows the last destinations stored in the navigation system. -If several last destinations are stored in the navigation system the channel _name_ contains all addresses as options. - -* Channel Group ID is **destination** -* Available if *LastDestinations* is present in *Services Supported*. Check [Vehicle Properties](#properties) for further details -* Read/Write access - - -| Channel Label | Channel ID | Type | Access | -|----------------------|---------------|-----------|-------------| -| Name | name | String | Read/Write | -| GPS Coordinates | gps | Location | Read | - - - -#### Image - -Image representation of the vehicle. Size and viewport are writable and can be -The possible values are the same mentioned in [Thing Configuration](#thing-configuration). - -* Channel Group ID is **image** -* Available for all vehicles -* Read/Write access - -| Channel Label | Channel ID | Type | Access | -|----------------------------|---------------------|--------|----------| -| Rendered Vehicle Image | png | Image | Read | -| Image Viewport | view | String | Write | -| Image Picture Size | size | Number | Write | - -## Actions - -Get the _Actions_ object for your vehicle using the Thing ID - -* bmwconnecteddrive - Binding ID, don't change! -* bev_rex - [Thing UID](#things) of your car -* user - Thing ID of the [Bridge](#bridge) -* i3 - Thing ID of your car - -``` - val profile = getActions("bmwconnecteddrive", "bmwconnecteddrive:bev_rex:user:i3") -``` - -### Charge Profile Editing - -Like in the Charge Profile Channels 3 Timers are provided. Replace *X* with 1, 2 or 3 to address the right timer. - -| Function | Parameters | Returns | Description | -|---------------------------------------|------------------|---------------------------|------------------------------------------------------------| -| getClimatizationEnabled | void | Boolean | Returns the enabled state of climatization | -| setClimatizationEnabled | Boolean | void | Sets the enabled state of climatization | -| getChargingMode | void | String | Gets the charging-mode, see valid options below | -| setChargingMode | String | void | Sets the charging-mode, see valid options below | -| getPreferredWindowStart | void | LocalTime | Returns the preferred charging-window start time | -| setPreferredWindowStart | LocalTime | void | Sets the preferred charging-window start time | -| getPreferredWindowEnd | void | LocalTime | Returns the preferred charging-window end time | -| setPreferredWindowEnd | LocalTime | void | Sets the preferred charging-window end time | -| getTimer*X*Enabled | void | Boolean | Returns the enabled state of timer*X* | -| setTimer*X*Enabled | Boolean | void | Returns the enabled state of timer*X* | -| getTimer*X*Departure | void | LocalTime | Returns the departure time of timer*X* | -| setTimer*X*Departure | LocalTime | void | Sets the timer*X* departure time | -| getTimer*X*Days | void | Set | Returns the days of week timer*X* is enabled for | -| setTimer*X*Days | Set | void | sets the days of week timer*X* is enabled for | -| getOverrideTimerEnabled | void | Boolean | Returns the enabled state of override timer | -| setOverrideTimerEnabled | Boolean | void | Sets the enabled state of override timer | -| getOverrideTimerDeparture | void | LocalTime | Returns the departure time of override timer | -| setOverrideTimerDeparture | LocalTime | void | Sets the override timer departure time | -| getOverrideTimerDays | void | Set | Returns the days of week the overrideTimer is enabled for | -| setOverrideTimerDays | Set | void | Sets the days of week the overrideTimer is enabled for | -| cancelEditChargeProfile | void | void | Cancel current edit of charging profile | -| sendChargeProfile | void | void | Sends the charging profile to the vehicle | - -Values for valid charging mode get/set - -* *IMMEDIATE_CHARGING* -* *DELAYED_CHARGING* - - -## Further Descriptions - -### Dynamic Data - - - -There are 3 occurrences of dynamic data delivered - -* Upcoming Services delivered in group [Services](#services) -* Check Control Messages delivered in group [Check Control](#check-control) -* Last Destinations delivered in group [Destinations](#destinations) - -The channel id _name_ shows the first element as default. -All other possibilities are attached as options. -The picture on the right shows the _Service Name_ item and all four possible options. -Select the desired service and the corresponding _Service Date & Milage_ will be shown. - -### TroubleShooting - -BMW has a high range of vehicles supported by ConnectedDrive. -In case of any issues with this binding help to resolve it! -Please perform the following steps: - -* Can you [log into ConnectedDrive](https://www.bmw-connecteddrive.com/country-region-select/country-region-selection.html) with your credentials? Please note this isn't the BMW Customer portal - it's the ConnectedDrive portal -* Is the vehicle listed in your account? There's a one-to-one relation from user to vehicle - -If the access to the portal is working and the vehicle is listed some debug data is needed in order to identify the issue. - -#### Generate Debug Fingerprint - -If you checked the above pre-conditions you need to get the debug fingerprint from the logs. -First [enable debug logging](https://www.openhab.org/docs/administration/logging.html#defining-what-to-log) for the binding. - -``` -log:set DEBUG org.openhab.binding.bmwconnecteddrive -``` - -The debug fingerprint is generated immediately after the vehicle thing is initialized the first time, e.g. after openHAB startup. -To force a new fingerprint disable the thing shortly and enable it again. -Personal data is eliminated from the log entries so it should be possible to share them in public. -Data like - -* Dealer Properties -* Vehicle Identification Number (VIN) -* Location latitude / longitude - -are anonymized. -You'll find the fingerprint in the logs with the command - -``` -grep "Troubleshoot Fingerprint Data" openhab.log -``` - -After the corresponding fingerprint is generated please [follow the instructions to raise an issue](https://community.openhab.org/t/how-to-file-an-issue/68464) and attach the fingerprint data! -Your feedback is highly appreciated! - - -### Range vs Range Radius - - - -You will observe differences in the vehicle range and range radius values. -While range is indicating the possible distance to be driven on roads the range radius indicates the reachable range on the map. - -The right picture shows the distance between Kassel and Frankfurt in Germany. -While the air-line distance is ~145 kilometer the route distance is ~192 kilometer. -So range value is the normal remaining range while the range radius values can be used e.g. on [Mapview](https://www.openhab.org/docs/configuration/sitemaps.html#element-type-mapview) to indicate the reachable range on map. -Please note this is just an indicator of the effective range. -Especially for electric vehicles it depends on many factors like driving style and usage of electric consumers. - -## Full Example - -The example is based on a BMW i3 with range extender (REX). -Exchange the three configuration parameters in the Things section - -* YOUR_USERNAME - with your ConnectedDrive login username -* YOUR_PASSWORD - with your ConnectedDrive password credentials -* VEHICLE_VIN - the vehicle identification number - -In addition search for all occurrences of *i3* and replace it with your Vehicle Identification like *x3* or *535d* and you're ready to go! - -### Things File - -``` -Bridge bmwconnecteddrive:account:user "BMW ConnectedDrive Account" [userName="YOUR_USERNAME",password="YOUR_PASSWORD",region="ROW"] { - Thing bev_rex i3 "BMW i3 94h REX" [ vin="VEHICLE_VIN",units="AUTODETECT",imageSize=600,imageViewport="FRONT",refreshInterval=5] -} -``` - -### Items File - -``` -Number:Length i3Mileage "Odometer [%d %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:range#mileage" } -Number:Length i3Range "Range [%d %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:range#hybrid"} -Number:Length i3RangeElectric "Electric Range [%d %unit%]" (i3,long) {channel="bmwconnecteddrive:bev_rex:user:i3:range#electric"} -Number:Length i3RangeFuel "Fuel Range [%d %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:range#fuel"} -Number:Dimensionless i3BatterySoc "Battery Charge [%.1f %%]" (i3,long) {channel="bmwconnecteddrive:bev_rex:user:i3:range#soc"} -Number:Volume i3Fuel "Fuel [%.1f %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:range#remaining-fuel"} -Number:Length i3RadiusElectric "Electric Radius [%d %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:range#radius-electric" } -Number:Length i3RadiusHybrid "Hybrid Radius [%d %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:range#radius-hybrid" } - -String i3DoorStatus "Door Status [%s]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#doors" } -String i3WindowStatus "Window Status [%s]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#windows" } -String i3LockStatus "Lock Status [%s]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#lock" } -DateTime i3NextServiceDate "Next Service Date [%1$tb %1$tY]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#service-date" } -String i3NextServiceMileage "Next Service Mileage [%d %unit%]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#service-mileage" } -String i3CheckControl "Check Control [%s]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#check-control" } -String i3ChargingStatus "Charging [%s]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#charge" } -DateTime i3LastUpdate "Update [%1$tA, %1$td.%1$tm. %1$tH:%1$tM]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:status#last-update"} - -DateTime i3TripDateTime "Trip Date [%1$tA, %1$td.%1$tm. %1$tH:%1$tM]" (i3) {channel="bmwconnecteddrive:bev_rex:user:i3:last-trip#date"} -Number:Time i3TripDuration "Trip Duration [%d %unit%]"