[tesla] Add support for setting charging amps and sentry mode (#12029)
* Add support for setting charging amps and sentry mode Signed-off-by: Kai Kreuzer <kai@openhab.org>
This commit is contained in:
parent
e9b0620c86
commit
a1e6a4e35c
|
@ -111,9 +111,9 @@ Additionally, these advanced channels are available (not all are available on al
|
|||
| chargelimitmaximum | Dimmer | Charge Limit Maximum | Maximum charging limit of the vehicle, as % |
|
||||
| chargelimitminimum | Dimmer | Charge Limit Minimum | Minimum charging limit of the vehicle, as % |
|
||||
| chargelimitsocstandard | Dimmer | Charge Limit SOC Standard | Standard charging limit of the vehicle, in % |
|
||||
| chargeidealdistanceadded | Number:Length | "Ideal" Charge Distance Added | "Ideal" range added during the last charging session |
|
||||
| chargeidealdistanceadded | Number:Length | Ideal Charge Distance Added | Ideal range added during the last charging session |
|
||||
| chargemaxcurrent | Number:ElectricCurrent | Charge Max Current | Maximum current (Ampere) that can be requested from the charger |
|
||||
| chargerateddistanceadded | Number:Length | "Rated" Charge Distance Added | "Rated" range added during the last charging session |
|
||||
| chargerateddistanceadded | Number:Length | Rated Charge Distance Added | Rated range added during the last charging session |
|
||||
| chargerate | Number:Speed | Charge Rate | Distance per hour charging rate |
|
||||
| chargestartingrange | String | Charge Starting Range | Undocumented / To be defined |
|
||||
| chargestartingsoc | String | Charge Starting SOC | Undocumented / To be defined |
|
||||
|
@ -123,6 +123,7 @@ Additionally, these advanced channels are available (not all are available on al
|
|||
| chargermaxcurrent | Number:ElectricCurrent | Charger Maximum Current | Maximum current (Ampere) that can be delivered by the charger |
|
||||
| chargerpower | Number | Charger Power | Power actually delivered by the charger |
|
||||
| chargervoltage | Number:ElectricPotential | Charger Voltage | Voltage (V) actually presented by the charger |
|
||||
| chargingamps | Number:ElectricCurrent | Set Charging Amps | Current (Ampere) to use for charging |
|
||||
| driverfrontdoor | Contact | Driver Front Door | Indicates if the front door at the driver's side is open |
|
||||
| driverreardoor | Contact | Driver Rear Door | Indicates if the rear door at the driver's side is open |
|
||||
| drivertemp | Number:Temperature | Driver Temperature | Indicates the auto conditioning temperature set at the driver's side |
|
||||
|
@ -174,6 +175,8 @@ Additionally, these advanced channels are available (not all are available on al
|
|||
| righttempdirection | Number | Right Temperature Direction | Not documented / To be defined |
|
||||
| scheduledchargingpending | Switch | Scheduled Charging Pending | Indicates if a scheduled charging session is still pending |
|
||||
| scheduledchargingstart | DateTime | Scheduled Charging Start | Indicates when the scheduled charging session will start, in yyyy-MM-dd'T'HH:mm:ss format |
|
||||
| sentrymode | Switch | Sentry Mode | Activates or deactivates sentry mode |
|
||||
| sentrymodeavailable | Switch | Sentry Mode Available | Indicates whether sentry mode is currently available |
|
||||
| shiftstate | String | Shift State | Indicates the state of the transmission, “P”, “D”, “R”, or “N” |
|
||||
| sidemirrorheaters | Switch | Side Mirror Heaters | Indicates if the side mirror heaters are switched on |
|
||||
| smartpreconditioning | Switch | Smart Preconditioning | Indicates if smart preconditioning is switched on |
|
||||
|
|
|
@ -60,7 +60,9 @@ public class TeslaBindingConstants {
|
|||
public static final String COMMAND_HONK_HORN = "honk_horn";
|
||||
public static final String COMMAND_OPEN_CHARGE_PORT = "charge_port_door_open";
|
||||
public static final String COMMAND_RESET_VALET_PIN = "reset_valet_pin";
|
||||
public static final String COMMAND_SET_CHARGING_AMPS = "set_charging_amps";
|
||||
public static final String COMMAND_SET_CHARGE_LIMIT = "set_charge_limit";
|
||||
public static final String COMMAND_SET_SENTRY_MODE = "set_sentry_mode";
|
||||
public static final String COMMAND_SET_TEMP = "set_temps";
|
||||
public static final String COMMAND_SET_VALET_MODE = "set_valet_mode";
|
||||
public static final String COMMAND_SUN_ROOF = "sun_roof_control";
|
||||
|
|
|
@ -177,6 +177,7 @@ public class TeslaChannelSelectorProxy {
|
|||
return new QuantityType<>(value, ImperialUnits.MILES_PER_HOUR);
|
||||
}
|
||||
},
|
||||
CHARGE_AMPS("charge_amps", "chargingamps", DecimalType.class, false),
|
||||
CHARGE_STARTING_RANGE("charge_starting_range", "chargestartingrange", StringType.class, false),
|
||||
CHARGE_STARTING_SOC("charge_starting_soc", "chargestartingsoc", StringType.class, false),
|
||||
CHARGE_STATE("charging_state", "chargingstate", StringType.class, false),
|
||||
|
@ -840,6 +841,30 @@ public class TeslaChannelSelectorProxy {
|
|||
return super.getState(dateFormatter.format(date));
|
||||
}
|
||||
},
|
||||
SENTRY_MODE("sentry_mode", "sentrymode", OnOffType.class, false) {
|
||||
@Override
|
||||
public State getState(String s, TeslaChannelSelectorProxy proxy, Map<String, String> properties) {
|
||||
if (s.equals("true") || s.equals("1")) {
|
||||
return super.getState("ON");
|
||||
}
|
||||
if (s.equals("false") || s.equals("0")) {
|
||||
return super.getState("OFF");
|
||||
}
|
||||
return super.getState(s);
|
||||
}
|
||||
},
|
||||
SENTRY_MODE_AVAILABLE("sentry_mode_available", "sentrymodeavailable", OnOffType.class, false) {
|
||||
@Override
|
||||
public State getState(String s, TeslaChannelSelectorProxy proxy, Map<String, String> properties) {
|
||||
if (s.equals("true") || s.equals("1")) {
|
||||
return super.getState("ON");
|
||||
}
|
||||
if (s.equals("false") || s.equals("0")) {
|
||||
return super.getState("OFF");
|
||||
}
|
||||
return super.getState(s);
|
||||
}
|
||||
},
|
||||
SHIFTSTATE("shift_state", "shiftstate", StringType.class, false),
|
||||
SIDEMIRROR_HEATING("side_mirror_heaters", "sidemirrorheaters", OnOffType.class, false) {
|
||||
@Override
|
||||
|
|
|
@ -344,7 +344,7 @@ public class TeslaAccountHandler extends BaseBridgeHandler {
|
|||
|
||||
try {
|
||||
JsonObject jsonObject = JsonParser.parseString(response.readEntity(String.class)).getAsJsonObject();
|
||||
logger.trace("Request : {}:{}:{} yields {}", command, payLoad, target, jsonObject.get("response"));
|
||||
logger.trace("Request : {}:{} yields {}", command, payLoad, jsonObject.get("response"));
|
||||
return jsonObject.get("response").toString();
|
||||
} catch (Exception e) {
|
||||
logger.error("An exception occurred while invoking a REST request: '{}'", e.getMessage());
|
||||
|
|
|
@ -54,12 +54,14 @@ import org.openhab.binding.tesla.internal.protocol.Vehicle;
|
|||
import org.openhab.binding.tesla.internal.protocol.VehicleState;
|
||||
import org.openhab.binding.tesla.internal.throttler.QueueChannelThrottler;
|
||||
import org.openhab.binding.tesla.internal.throttler.Rate;
|
||||
import org.openhab.core.library.types.DecimalType;
|
||||
import org.openhab.core.library.types.IncreaseDecreaseType;
|
||||
import org.openhab.core.library.types.OnOffType;
|
||||
import org.openhab.core.library.types.PercentType;
|
||||
import org.openhab.core.library.types.QuantityType;
|
||||
import org.openhab.core.library.types.StringType;
|
||||
import org.openhab.core.library.unit.SIUnits;
|
||||
import org.openhab.core.library.unit.Units;
|
||||
import org.openhab.core.thing.ChannelUID;
|
||||
import org.openhab.core.thing.Thing;
|
||||
import org.openhab.core.thing.ThingStatus;
|
||||
|
@ -263,6 +265,26 @@ public class TeslaVehicleHandler extends BaseThingHandler {
|
|||
}
|
||||
break;
|
||||
}
|
||||
case CHARGE_AMPS:
|
||||
Integer amps = null;
|
||||
if (command instanceof DecimalType) {
|
||||
amps = ((DecimalType) command).intValue();
|
||||
}
|
||||
if (command instanceof QuantityType<?>) {
|
||||
QuantityType<?> qamps = ((QuantityType<?>) command).toUnit(Units.AMPERE);
|
||||
if (qamps != null) {
|
||||
amps = qamps.intValue();
|
||||
}
|
||||
}
|
||||
if (amps != null) {
|
||||
if (amps < 5 || amps > 32) {
|
||||
logger.warn("Charging amps can only be set in a range of 5-32A, but not to {}A.",
|
||||
amps);
|
||||
return;
|
||||
}
|
||||
setChargingAmps(amps);
|
||||
}
|
||||
break;
|
||||
case COMBINED_TEMP: {
|
||||
QuantityType<Temperature> quantity = commandToQuantityType(command);
|
||||
if (quantity != null) {
|
||||
|
@ -284,6 +306,12 @@ public class TeslaVehicleHandler extends BaseThingHandler {
|
|||
}
|
||||
break;
|
||||
}
|
||||
case SENTRY_MODE: {
|
||||
if (command instanceof OnOffType) {
|
||||
setSentryMode(command == OnOffType.ON);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case SUN_ROOF_STATE: {
|
||||
if (command instanceof StringType) {
|
||||
setSunroof(command.toString());
|
||||
|
@ -565,6 +593,20 @@ public class TeslaVehicleHandler extends BaseThingHandler {
|
|||
requestData(CHARGE_STATE);
|
||||
}
|
||||
|
||||
public void setChargingAmps(int amps) {
|
||||
JsonObject payloadObject = new JsonObject();
|
||||
payloadObject.addProperty("charging_amps", amps);
|
||||
sendCommand(COMMAND_SET_CHARGING_AMPS, gson.toJson(payloadObject), account.commandTarget);
|
||||
requestData(CHARGE_STATE);
|
||||
}
|
||||
|
||||
public void setSentryMode(boolean b) {
|
||||
JsonObject payloadObject = new JsonObject();
|
||||
payloadObject.addProperty("on", b);
|
||||
sendCommand(COMMAND_SET_SENTRY_MODE, gson.toJson(payloadObject), account.commandTarget);
|
||||
requestData(VEHICLE_STATE);
|
||||
}
|
||||
|
||||
public void setSunroof(String state) {
|
||||
if (state.equals("vent") || state.equals("close")) {
|
||||
JsonObject payloadObject = new JsonObject();
|
||||
|
|
|
@ -41,6 +41,7 @@ public class ChargeState {
|
|||
public float ideal_battery_range;
|
||||
public float time_to_full_charge;
|
||||
public int battery_level;
|
||||
public int charge_amps;
|
||||
public int charge_current_request;
|
||||
public int charge_current_request_max;
|
||||
public int charge_limit_soc;
|
||||
|
|
|
@ -92,8 +92,8 @@ channel-type.tesla.chargeenablerequest.label = Charge Enable Request
|
|||
channel-type.tesla.chargeenablerequest.description = Undocumented / To be defined
|
||||
channel-type.tesla.chargeenergyadded.label = Charge Energy Added
|
||||
channel-type.tesla.chargeenergyadded.description = Energy added, in kWh, during the last charging session
|
||||
channel-type.tesla.chargeidealdistanceadded.label = "Ideal" Charge Distance Added
|
||||
channel-type.tesla.chargeidealdistanceadded.description = "Ideal" range added during the last charging session
|
||||
channel-type.tesla.chargeidealdistanceadded.label = Ideal Charge Distance Added
|
||||
channel-type.tesla.chargeidealdistanceadded.description = Ideal range added during the last charging session
|
||||
channel-type.tesla.chargelimit.label = Charge Limit
|
||||
channel-type.tesla.chargelimit.description = Limit charging of the vehicle to the given %
|
||||
channel-type.tesla.chargelimitmaximum.label = Charge Limit Maximum
|
||||
|
@ -108,8 +108,8 @@ channel-type.tesla.chargeport.label = Charge Port
|
|||
channel-type.tesla.chargeport.description = Open the Charge Port (ON) or indicates the state of the Charge Port (ON/OFF if Open/Closed)
|
||||
channel-type.tesla.chargerate.label = Charge Rate
|
||||
channel-type.tesla.chargerate.description = Distance per hour charging rate
|
||||
channel-type.tesla.chargerateddistanceadded.label = "Rated" Charge Distance Added
|
||||
channel-type.tesla.chargerateddistanceadded.description = "Rated" range added during the last charging session
|
||||
channel-type.tesla.chargerateddistanceadded.label = Rated Charge Distance Added
|
||||
channel-type.tesla.chargerateddistanceadded.description = Rated range added during the last charging session
|
||||
channel-type.tesla.chargercurrent.label = Charge Current
|
||||
channel-type.tesla.chargercurrent.description = Current (Ampere) actually being drawn from the charger
|
||||
channel-type.tesla.chargermaxcurrent.label = Charger Maximum Current
|
||||
|
@ -126,6 +126,8 @@ channel-type.tesla.chargestartingsoc.label = Charge Starting SOC
|
|||
channel-type.tesla.chargestartingsoc.description = Undocumented / To be defined
|
||||
channel-type.tesla.chargetomax.label = Charge To Max Range
|
||||
channel-type.tesla.chargetomax.description = Indicates if the charging to the maximum range is enabled
|
||||
channel-type.tesla.chargingamps.label = Set Charging Amps
|
||||
channel-type.tesla.chargingamps.description = Current (Ampere) to use for charging
|
||||
channel-type.tesla.chargingstate.label = Charging State
|
||||
channel-type.tesla.chargingstate.description = “Starting”, “Complete”, “Charging”, “Disconnected”, “Stopped”, “NoPower”
|
||||
channel-type.tesla.chargingstate.state.option.Starting = Starting
|
||||
|
@ -246,6 +248,10 @@ channel-type.tesla.scheduledchargingpending.label = Scheduled Charging Pending
|
|||
channel-type.tesla.scheduledchargingpending.description = Indicates if a scheduled charging session is still pending
|
||||
channel-type.tesla.scheduledchargingstart.label = Scheduled Charging Start
|
||||
channel-type.tesla.scheduledchargingstart.description = Indicates when the scheduled charging session will start, in yyyy-MM-dd'T'HH:mm:ss format
|
||||
channel-type.tesla.sentrymode.label = Sentry Mode
|
||||
channel-type.tesla.sentrymode.description = Activates or deactivates sentry mode
|
||||
channel-type.tesla.sentrymodeavailable.label = Sentry Available
|
||||
channel-type.tesla.sentrymodeavailable.description = Indicates whether sentry mode is currently available
|
||||
channel-type.tesla.shiftstate.label = Shift State
|
||||
channel-type.tesla.shiftstate.description = Indicates the state of the transmission, “P”, “D”, “R”, or “N”
|
||||
channel-type.tesla.sidemirrorheaters.label = Side Mirror Heaters
|
||||
|
|
|
@ -92,6 +92,12 @@
|
|||
<description>Undocumented / To be defined</description>
|
||||
<state readOnly="true"></state>
|
||||
</channel-type>
|
||||
<channel-type id="chargingamps" advanced="true">
|
||||
<item-type>Number:ElectricCurrent</item-type>
|
||||
<label>Set Charging Amps</label>
|
||||
<description>Current (Ampere) to use for charging</description>
|
||||
<state pattern="%.0f A"></state>
|
||||
</channel-type>
|
||||
<channel-type id="chargecurrent" advanced="true">
|
||||
<item-type>Number:ElectricCurrent</item-type>
|
||||
<label>Charge Current</label>
|
||||
|
@ -136,8 +142,8 @@
|
|||
</channel-type>
|
||||
<channel-type id="chargeidealdistanceadded" advanced="true">
|
||||
<item-type>Number:Length</item-type>
|
||||
<label>"Ideal" Charge Distance Added</label>
|
||||
<description>"Ideal" range added during the last charging session</description>
|
||||
<label>Ideal Charge Distance Added</label>
|
||||
<description>Ideal range added during the last charging session</description>
|
||||
<state pattern="%d %unit%" readOnly="true"></state>
|
||||
</channel-type>
|
||||
<channel-type id="chargemaxcurrent" advanced="true">
|
||||
|
@ -148,8 +154,8 @@
|
|||
</channel-type>
|
||||
<channel-type id="chargerateddistanceadded" advanced="true">
|
||||
<item-type>Number:Length</item-type>
|
||||
<label>"Rated" Charge Distance Added</label>
|
||||
<description>"Rated" range added during the last charging session</description>
|
||||
<label>Rated Charge Distance Added</label>
|
||||
<description>Rated range added during the last charging session</description>
|
||||
<state pattern="%d %unit%" readOnly="true"></state>
|
||||
</channel-type>
|
||||
<channel-type id="chargerate" advanced="true">
|
||||
|
@ -415,7 +421,7 @@
|
|||
</channel-type>
|
||||
<channel-type id="notenoughpower" advanced="true">
|
||||
<item-type>Switch</item-type>
|
||||
<label>Not Enought Power </label>
|
||||
<label>Not Enought Power</label>
|
||||
<description>Indicates if not enough power (ON) is available to heat the vehicle</description>
|
||||
<state readOnly="true"></state>
|
||||
</channel-type>
|
||||
|
@ -550,6 +556,17 @@
|
|||
<description>Indicates when the scheduled charging session will start, in yyyy-MM-dd'T'HH:mm:ss format</description>
|
||||
<state readOnly="true"></state>
|
||||
</channel-type>
|
||||
<channel-type id="sentrymode" advanced="true">
|
||||
<item-type>Switch</item-type>
|
||||
<label>Sentry Mode</label>
|
||||
<description>Activates or deactivates sentry mode</description>
|
||||
</channel-type>
|
||||
<channel-type id="sentrymodeavailable" advanced="true">
|
||||
<item-type>Switch</item-type>
|
||||
<label>Sentry Available</label>
|
||||
<description>Indicates whether sentry mode is currently available</description>
|
||||
<state readOnly="true"></state>
|
||||
</channel-type>
|
||||
<channel-type id="shiftstate" advanced="true">
|
||||
<item-type>String</item-type>
|
||||
<label>Shift State</label>
|
||||
|
|
|
@ -26,6 +26,7 @@
|
|||
<channel id="centerrearseatheater" typeId="centerrearseatheater"/>
|
||||
<channel id="charge" typeId="charge"/>
|
||||
<channel id="chargecable" typeId="chargecable"/>
|
||||
<channel id="chargingamps" typeId="chargingamps"/>
|
||||
<channel id="chargecurrent" typeId="chargecurrent"/>
|
||||
<channel id="chargeenablerequest" typeId="chargeenablerequest"/>
|
||||
<channel id="chargeenergyadded" typeId="chargeenergyadded"/>
|
||||
|
@ -100,6 +101,8 @@
|
|||
<channel id="rightseatheater" typeId="rightseatheater"/>
|
||||
<channel id="scheduledchargingpending" typeId="scheduledchargingpending"/>
|
||||
<channel id="scheduledchargingstart" typeId="scheduledchargingstart"/>
|
||||
<channel id="sentrymode" typeId="sentrymode"/>
|
||||
<channel id="sentrymodeavailable" typeId="sentrymodeavailable"/>
|
||||
<channel id="shiftstate" typeId="shiftstate"/>
|
||||
<channel id="sidemirrorheaters" typeId="sidemirrorheaters"/>
|
||||
<channel id="smartpreconditioning" typeId="smartpreconditioning"/>
|
||||
|
|
|
@ -28,6 +28,7 @@
|
|||
<channel id="centerrearseatheater" typeId="centerrearseatheater"/>
|
||||
<channel id="charge" typeId="charge"/>
|
||||
<channel id="chargecable" typeId="chargecable"/>
|
||||
<channel id="chargingamps" typeId="chargingamps"/>
|
||||
<channel id="chargecurrent" typeId="chargecurrent"/>
|
||||
<channel id="chargeenablerequest" typeId="chargeenablerequest"/>
|
||||
<channel id="chargeenergyadded" typeId="chargeenergyadded"/>
|
||||
|
@ -103,6 +104,8 @@
|
|||
<channel id="rightseatheater" typeId="rightseatheater"/>
|
||||
<channel id="scheduledchargingpending" typeId="scheduledchargingpending"/>
|
||||
<channel id="scheduledchargingstart" typeId="scheduledchargingstart"/>
|
||||
<channel id="sentrymode" typeId="sentrymode"/>
|
||||
<channel id="sentrymodeavailable" typeId="sentrymodeavailable"/>
|
||||
<channel id="shiftstate" typeId="shiftstate"/>
|
||||
<channel id="sidemirrorheaters" typeId="sidemirrorheaters"/>
|
||||
<channel id="smartpreconditioning" typeId="smartpreconditioning"/>
|
||||
|
|
|
@ -28,6 +28,7 @@
|
|||
<channel id="centerrearseatheater" typeId="centerrearseatheater"/>
|
||||
<channel id="charge" typeId="charge"/>
|
||||
<channel id="chargecable" typeId="chargecable"/>
|
||||
<channel id="chargingamps" typeId="chargingamps"/>
|
||||
<channel id="chargecurrent" typeId="chargecurrent"/>
|
||||
<channel id="chargeenablerequest" typeId="chargeenablerequest"/>
|
||||
<channel id="chargeenergyadded" typeId="chargeenergyadded"/>
|
||||
|
@ -103,6 +104,8 @@
|
|||
<channel id="rightseatheater" typeId="rightseatheater"/>
|
||||
<channel id="scheduledchargingpending" typeId="scheduledchargingpending"/>
|
||||
<channel id="scheduledchargingstart" typeId="scheduledchargingstart"/>
|
||||
<channel id="sentrymode" typeId="sentrymode"/>
|
||||
<channel id="sentrymodeavailable" typeId="sentrymodeavailable"/>
|
||||
<channel id="shiftstate" typeId="shiftstate"/>
|
||||
<channel id="sidemirrorheaters" typeId="sidemirrorheaters"/>
|
||||
<channel id="smartpreconditioning" typeId="smartpreconditioning"/>
|
||||
|
|
|
@ -27,6 +27,7 @@
|
|||
<channel id="centerrearseatheater" typeId="centerrearseatheater"/>
|
||||
<channel id="charge" typeId="charge"/>
|
||||
<channel id="chargecable" typeId="chargecable"/>
|
||||
<channel id="chargingamps" typeId="chargingamps"/>
|
||||
<channel id="chargecurrent" typeId="chargecurrent"/>
|
||||
<channel id="chargeenablerequest" typeId="chargeenablerequest"/>
|
||||
<channel id="chargeenergyadded" typeId="chargeenergyadded"/>
|
||||
|
@ -102,6 +103,8 @@
|
|||
<channel id="rightseatheater" typeId="rightseatheater"/>
|
||||
<channel id="scheduledchargingpending" typeId="scheduledchargingpending"/>
|
||||
<channel id="scheduledchargingstart" typeId="scheduledchargingstart"/>
|
||||
<channel id="sentrymode" typeId="sentrymode"/>
|
||||
<channel id="sentrymodeavailable" typeId="sentrymodeavailable"/>
|
||||
<channel id="shiftstate" typeId="shiftstate"/>
|
||||
<channel id="sidemirrorheaters" typeId="sidemirrorheaters"/>
|
||||
<channel id="smartpreconditioning" typeId="smartpreconditioning"/>
|
||||
|
|
Loading…
Reference in New Issue