Tesla vehicles have a sleep mode which allows the vehicle to conserve battery power when not actively operating. After a period of inactivity, the vehicle will power down systems which are not necessary during times of inactivity.
One challenge of Tesla API-based Data Loggers is that the continual polling of vehicles via the API results in the vehicle failing to go into sleep mode. To avoid these scenarios, TeslaMate uses two configuration parameters to define when a vehicle will start to sleep due to inactivity.
Following activity such as driving or charging, TeslaMate will continue to actively poll a vehicle for a configurable amount of time (by default 15 Minutes) in order to detect whether the vehicle will continue to be in active use (for example, whether the vehicle has stopped temporarily to pick up a passenger or to visit a shop) or whether it will return to idle state.
- If this value is set too low, the car may attempt to sleep prior to actually being idle. In this case, you may miss subsequent parts of a trip, for example if you had stopped for 20 minutes to pick up some items but the idle time was set to 15 minutes, the car would attempt to sleep.
- If this value is set too high, the time after a drive during which the car is continually actively polled and is unable to go to sleep will be longer than necessary, consuming a greater amount of battery power.
Once the idle timer is reached, TeslaMate will try to allow the car to go to sleep. It does this by halting all polling for the configured time period, which is 21 Minutes by default.
- You will know that the vehicle is in this state when the status in TeslaMate is falling asleep for x minutes.
- At the end of this polling window, TeslaMate will poll the vehicle status.
- If the vehicle status is offline or asleep, this indicates that the sleep process succeeded and the car is no longer directly queryable.
- If the vehicle is still online – which may sometimes happen due to e.g. background activity – TeslaMate will repeatedly halt polling for the configured time period until the vehicle is asleep.
- Once the vehicle is offline/asleep polling will continue once per minute so that TeslaMate knows when the vehicle is woken up
If you were to drive a vehicle that has just woken from Sleep Mode immediately after polling was halted, TeslaMate would miss 21 minutes (by default) of the drive session.
Tested By | Vehicle Model + Year | Software Version | Time to Try Sleeping | Outcome |
---|---|---|---|---|
@adriankumpf | Model 3 AP 2019 | any | 12 Minutes | Vehicle sleeps perfectly |
@ngardiner | Model 3 MY 2019 (MCU2) | 2019.32.11.1 | 15 Minutes | Vehicle sleeps without issue |
@ngardiner | Model 3 MY 2019 (MCU2) | 2019.32.11.1 | 12 Minutes | Currently testing this setting |
To address this delay, interfaces are available to TeslaMate to instruct it to expect:
- The vehicle to go to sleep, or
- The vehicle to wake up
Using Bluetooth hints, a tool like Tasker on the phone can then detect the Bluetooth connection between the phone and the vehicle, and send a hint to TeslaMate to anticipate that the vehicle will wake up, and to resume high-frequency polling. The following sections of the document deal with different phone platforms and how to set up Bluetooth hints for those platforms.
If you are specifying the local (LAN) IP address/port of your TeslaMate instance when performing the wake up, this may fail for a number of reasons:
- It will not provide hints to TeslaMate when you are outside of your home network (ie if you have been driving).
- It will not provide hints to TeslaMate if the mobile phone becomes disconnected from the wifi network.
For these reasons, it is necessary to use a method that allows external communication between your smartphone and your TeslaMate instance. There are two key ways that this can be achieved:
- Use a VPN solution such as Wireguard or OpenVPN.
- Make your TeslaMate instance publicly available (see Advanved Docker Setup for an example).
There are a number of applicatons that provide this functionality on Android:
Application | Price | Guide(s) |
---|---|---|
Tasker | US$3.00* | Tasker Setup |
MacroDroid | Free (Limited) | MacroDroid Setup |
Automagic | US$3.50* | N/A |
*If you’re going to pay for an app anyway, consider donating to this project as well 😎
On the iOS platform, Apple provides the Shortcuts workflow tool:
Application | Price | Guide(s) |
---|---|---|
Shortcuts | Free | Shortcuts Setup |
In addition to Bluetooth hints, which would address most use cases, it is also possible to institute event-based hints. An example of an event-based hint is to trigger a callback to TeslaMate when your Garage Door is opened via HomeAssistant. The relevant configuration for this is:
-
automations.yaml
- alias: Wake Teslamate on Garage Open initial_state: on trigger: - platform: state entity_id: switch.garage_door_switch to: 'off' action: - service: script.turn_on entity_id: script.wake_teslamate
-
script.yaml
wake_teslamate: sequence: - service: shell_command.wake_teslamate sleep_teslamate: sequence: - service: shell_command.sleep_teslamate
-
shell_command.yaml
Note: Substitute your IP address for the commands
sleep_teslamate: curl -X PUT http://192.168.1.1:4000/api/car/1/logging/suspend wake_teslamate: curl -X PUT http://192.168.1.1:4000/api/car/1/logging/resume
There are some parameters which are tunable on some Tesla vehicles. Keep in mind that as these differ between models and MCU versions, they may not be available on your vehicle. These are:
Always Connected is a setting available only on Model S and Model X vehicles with the MCU1 hardware. It is available under Settings > Controls > Displays > Power Management.
Some older vehicles have an energy-saving feature that reduces the amount of energy being consumed when not in use. On newer vehicles, this feature is automated to provide an optimal level of energy saving. It is available under Controls > Displays > Energy Saving.