Skip to content

Latest commit

Β 

History

History
1461 lines (995 loc) Β· 69.4 KB

CHANGELOG.md

File metadata and controls

1461 lines (995 loc) Β· 69.4 KB

Changelog

1.24.2 - 2021-09-29

Improvements and Bug Fixes

  • Discard stale data originating from the Tesla Streaming API
  • Broadcast offline state via MQTT when car goes offline while driving

Dashboards

1.24.1 - 2021-09-29

⚠️ NOTE: Tesla have tightened the captcha security once again and now require Google reCAPTCHA to generate API tokens. reCAPTCHA is implemented in a way that makes it impossible to bypass for applications like TeslaMate. There are third-party services that offer to fill these captchas (by having humans solve them manually), but they're slow and can be pricey if you're making a large a mount of requests.

So if you are having issues signing in to your Tesla account via TeslaMate, the only remaining workaround right now is to sign in using existing API tokens (there is a button on the TeslaMate sign-in form). There are multiple apps available to securely generate access tokens yourself, for example:

Users who are already signed in in do not have to worry about it. TeslaMate will continue to be able to access the Tesla API.

1.24.0 - 2021-08-31

Improvements and Bug Fixes

  • Tesla have once again made changes to the login: TeslaMate can now handle a delayed captcha that first appears after submitting the login form …
  • Handle Tesla OwnerAPI errors returned by streaming API
  • Lay the groundwork for the ability to customize the displayed order of vehicles (#1904 by leewillis77)
    • The order can currently be customized by manually updating the display_priority column in the cars database table

Dashboards

  • Charging Stats: Use the full range of colors in the heatmap (#1821 by dyxyl)
  • Projected Range: Change right y-axis battery level range max from 200% to 100% (#1840 by toneus)
  • Timeline: Fix for missing drives and add links to the Action column (1818 and #1872 by DrMichael)
  • Charge Level: Fix diagram glitch (#1936 by DrMichael)

Translations

Documentation

  • Add a note about RAM needed after having issues, also a small clarification on where to place the .env file in the advanced guide (#1857 by billerby)
  • Add note with custom TM_DB_USER when backing up (#1931 by kyleawayan)
  • Advanced installation with Traefik: Update Grafana rule to limit to TeslaMate host (#1937 by benoitm974)

1.23.7 - 2021-07-16

Improvements and Bug Fixes

  • Since Tesla have once again made changes to the login with captcha, this version fixes the problems caused by it
  • Update permissions to the Grafana plugin directory (#1814 by letienne)

Documentation

  • Fix heading of the Home Assistant binary_sensor config (#1756 by mrzeldaguy)

1.23.6 - 2021-07-08

Improvements and Bug Fixes

  • Disable sign-in button if captcha code is missing
  • Fix login for Chinese accounts

1.23.5 - 2021-07-08

Improvements and Bug Fixes

  • Fix login with captcha

Dashboards

  • Timeline: Make added kWh more accurate

1.23.4 - 2021-06-18

Improvements and Bug Fixes

Dashboards

  • Drive Details: Don't round down duration (#1677 by Dulanic)
  • Projected Range: Prevent division by zero (#1678 by Dulanic)
  • Updates / States / Stastistics: Use local browser time (#1685 by Ed-M72)
  • Charge Level: Simplify database query (#1693 by Dulanic)
  • Timeline: Add new category Missing and some other adjustments (#1708 by DrMichael)
  • Timeline: Fix missing datasources (#1730 by nickbock)
  • Bump Grafana to 7.5.8 (Docker image)

Documentation

1.23.3 - 2021-06-02

Bug Fixes

  • Fix API tokens form

1.23.2 - 2021-06-02

Bug Fixes

  • Fix sign-in for Chinese accounts

1.23.1 - 2021-06-02

Improvements and Bug Fixes

  • Tesla has removed the captcha again …
  • Fix error when changing the language to Chinese

Translations

1.23.0 - 2021-06-01

Improvements and Bug Fixes

  • Support Tesla's new captcha verification
  • Improve naming of addresses (city aliases)
  • Add power to published MQTT topics (#1504 by mnadvornik)
  • The Docker image now ships with Erlang/OTP 24 which comes with a JIT-compiler (enabled on most x86 64-bit platforms)
  • Only publish geofence via MQTT if it has changed
  • Fix calculation of gross consumption while charging
  • Fix service mode detection
  • Fix typo in code_challenge_method (#1571 by tuxbox)
  • Make dashboards.sh script portable e.g. to BSD (#1645 by tuxbox)

Dashboards

Translations

Documentation

  • Update Mosquitto version used in docker-compose examples
  • Add device classes and binary sensors to documented Home Assistant config (#1597 by flacjacket and #1634 by ffeingol)

1.22.0 - 2021-03-17

Improvements and Bug Fixes

  • Add option to sign in with existing API tokens
  • Avoid false plugged_in events (#1423 by brianmay)
  • Handle distinct OSM IDs gracefully when chaning the address language
  • Set another user agent for auth requests.
    • ⚠️ This fixes timeouts when signing in for the time being. Most users who are affected reported using a cloud hosting service. Expect this to break anytime Tesla decides to block this type of traffic coming from these providers.
  • Update user agent used for API requests to GitHub and OpenStreetMap

Dashboards

  • Add battery heater info to Overview / Charging Details and Charge Details dashboards (#1428 by ToniA)
  • Statistics: Calculate efficiency from charged energy (#1445 by ToniA)
  • Make Statistics dashboard look the same on both kilometers and miles (#1439 by ToniA)
  • Updates: Rename column to "Since Previous Update"

Translations

Documentation

  • Explaing the asleep mode with MCU1 and the non-streaming mode (#1453 by ToniA)

1.21.6 - 2021-03-10

Improvements and Bug Fixes

  • Change HTTP headers again to avoid auth requests timing out
  • Fix changing the address language
  • Add health check route (#1422 by brianmay)

Translations

Documentation

1.21.5 - 2021-02-21

Improvements and Bug Fixes

  • Implement a workaround for login requests timing out
  • Handle failed token refresh requests gracefully

Dashboards

  • Overview: Fix Gross Panel font size (#1363 by DrMichael)
  • Charging Stats: Set bucket size on charging heatmap (#1355 by leewillis77)
  • Downgrade Grafana to 7.3.7 because of an incompatibility with the Trackmap plugin

1.21.4 - 2021-02-16

Enhancements and Bug Fixes

  • Point out more clearly when starting into import mode
  • Hide sign-out button in import mode
  • Don't purge debug log statements from production release
  • Handle non-existing range values after the car was offline

Dashboards

  • Statistics: Show "Starting at" column and fix timezone issue (#1254 by DrMichael)
  • Charge Level: Fix usable battery level alternating between usable battery level and regular battery level
  • Bump Grafana to v7.4.1

Documentation

1.21.3 - 2021-02-06

  • Add support for v3 API tokens in China
  • Detect if TeslaFi CSV files contain data for more than one car
  • Change log level for streaming timeouts to debug

1.21.2 - 2021-01-31

⚠️ NOTE: Any previously stored API refresh tokens will no longer function, as Tesla has deprecated the existing authentication endpoint. Existing access tokens will continue to work until they expire. Eventually, a full login will be needed to obtain new refresh tokens.

To immediately obtain new tokens after upgrading, go to the TeslaMate settings page, sign out via the button at the bottom of the page and then sign in again.

⚠️ NOTE: This release changes TeslaMate's base Docker image to Debian. If you have any customizations on top of TeslaMate (like healthchecks), they could need updates to work on top of this new image.

Enhancements

  • Use the new Tesla authentication endpoint for refreshing access tokens
  • Drop support for the /oauth/token endpoint
  • Add a sign-out button at the bottom of the settings page

Translations

Dashboards

  • Display average outside temperature in charges dashboard (#1213 by DrMichael)

1.21.1 - 2021-01-10

Enhancements

Translations

Documentation

  • Add some documentation about updating TeslaMate when installed with Docker (#1170 by fatbasstard)
  • Update "Import from tesla-apiscraper" documentation: Give an example how to get the vehicle_id from TeslaMate (#1174 by Bdot42)
  • Add link to unofficial Home Assistant addon (#1188 by matt-FFFFFF)

Other

  • Allow to use non-standard MQTT ports (via MQTT_PORT)
  • Refactoring: Use built-in Ecto enum type
  • Guard against unexpected MFA errors

Bug Fixes

1.21.0 - 2021-01-02

Enhancements

Dashboards

  • Drive Details: Add button to download a drive as GPX file (#993 by ayonix)
  • New dashboard for reporting to Dutch tax (#998 and #1051 by roadrash2108)
  • Locations: Add panel to see when an address was last visited
  • Charges/Drives: Add more filtering capabilities (#1016 by Kosta-Github)
  • Overview: Fix unit of measurement for charge energy added (#1061 by landler)
  • Charge Level: Add green bars (20/80%) to match "Charge Delta" graph (#1059 by roadrash2108)
  • Charging-Stats/Trip: Change colors of AC/DC (#1058 by roadrash2108)
  • Statistics: Resolve issue with month groupings (#1082 by leewillis77)
  • Updates: Apply number of charges and average rated range to the correct update (#1147 by tlj)

Other

  • Add support for Tesla’s new authentication process (two-factor authentication)
  • Optimize TeslaFi CSV file import: reduced memory usage and increased performance
  • Require Elixir v1.11
  • Allow to connect to Postgres via IPv6 (via DATABASE_IPV6)
  • Allow to connect to MQTT broker via IPv6 (via MQTT_IPV6)
  • Improve detection of whether the vehicle is plugged in during cold weather (+ fix #1154 by virtualm2000)
  • Use connection pooling for SRTM downloads
  • Optimize Docker layer caching to speed up image build times
  • Battery level tooltip: Prevent division by zero error if car is totally down to 0%
  • Display the actual error if the import directory is not accessible

Translations

Documentation

1.20.1 - 2020-10-24

Enhancements

Dashboards

  • Charge Level: Always show 0% and 100% when state of charge is shown in a diagram (#980 by mbertheau)
  • Charging Stats: Titles/labels now match pie-charts (#998 by roadrash2108)
  • Drive Details: Increase width of odometer panel
  • Efficiency: Set a fixed max value and use LCD gauge
  • Overview: Fix overlapping timestamps in discrete map (#995 by pmboothby)
  • Fix overlapping timestamps in trip and states dashboard
  • Statistics: Add links to other dashboards (#973 by DrMichael)

Translations

Other

  • Display update version in the homescreen update tooltip (#976 by ayonix)
  • Customize Grafana home screen logo (#1004 by gimmespam)
  • Bump Grafana to 7.2.1

Bug Fixes

  • Fix tooltips in car overview being hidden by .card (#975 by ayonix)
  • Make Statistics dashboard compatible with older versions of Postgres
  • Open Statistics dashboard with browser time zone when coming from the TeslaMate UI

1.20.0 - 2020-10-04

Enhancements

Dashboards

  • Update consumption unit to Watt-hour to match in-car unit (#717 by mattw01)
  • Update dashboards to use the new components from Grafana 7
  • Charges: Show very short charging sessions
  • Charges: Add filter for voltage (#857 by Dulanic)
  • Charging Details: Show kWh even if still charging (#744 by Dulanic)
  • Charging Stats: Visualize % of sum instead of max kWh in charging heat map (#680 by Dulanic)
  • Charging Stats: Show cost per 100 km/mi (Charging Stats)
  • Drives: Update possible values for the "cold" column to be consistent (#702 by Dulanic)
  • Drive Details: Show drive efficiency
  • Mileage: Optimize query to get odometer (#804 by Dulanic)
  • Overview: Add 'total energy added' to chart (#690 by Dulanic)
  • Overview: Hide stale temperatures
  • Overview: Show most recent driver temp setting while driving
  • Overview: Add efficiency (#970 by DrMichael)
  • States: Display all states names (#755 by DrMichael)
  • Updates: Add links to release notes (#797 and #823 by pmboothby)
  • Updates: Show average range and number of chargers per software version to identify if an update had a bigger than expected impact on range (#731 and #762 by Dulanic)
  • Updates: Fix up the version display when it only has a week value and no point release (#925 by pyjamasam)
  • Vampire Drain: Utilize charges as additional anchor points (#769 by tacotran)
  • Add new Statistics dashboard (#965 by DrMichael)
  • Add the "shared crosshair" setting to some of the dashboards (#932 and #962 by Kosta-Github)
  • "Customize" Grafana logo (#890 by https://github.com/fatbasstard)
Note
  • The dashboards require Grafana 7. Make sure you are running the latest version of Grafana if you are not using the Docker installation.

Translations

Documentation

Other

  • Optimize conversion helper functions
  • Allow to set a cost by the minute per geo-fence
  • Allow to set charge cost by minute
  • Allow negative charge costs
  • Periodically store vehicle data while charging
  • Use a more performant HTTP client
  • Try to keep using API tokens if initial refresh at startup fails
  • Tweak streaming timeouts and create a new connection after too many disconnects
  • Change default sleep requirements to not require the car to be locked
  • Use GitHub Actions to build docker images and publish them to DockerHub
  • For those who want to help testing the latest development version: the docker images with the edge tag (teslamate/teslamate:edge and teslamate/grafana:edge) are for you.
  • Allow negative cost_per_unit for geofences (#968 by ayonix)
  • Speed up parsing of CSV files (data import)

Bug Fixes

  • Vampire Drain: Fix duplicate values with multiple cars (#726 by Dulanic)
  • Tooling: Ensure dashboards are restored into the same folder as they currently belong to (#712 by sumnerboy12)
  • Battery Level & Range: fix wrongly displayed values for multiple cars (#843 by lemmerk)
  • Fix handling of locations that cannot be geocoded
  • Show in progress charging sessions
  • Handle API errors during initialization

1.19.4 - 2020-06-04

1.19.3 - 2020-05-03

Enhancements

Translations

Dashboards

  • Overview: Update battery gauge thresholds (#651 by wooter)
  • Drives: Add column header for reduced range (#662 by Dulanic)
  • Charging Stats: Show map with frequently used chargers (#666 by Dulanic)
    • Manual install: requires Grafana plugin grafana-map-panel
      grafana-cli --pluginUrl https://github.com/panodata/grafana-map-panel/releases/download/0.9.0/grafana-map-panel-0.9.0.zip plugins install grafana-worldmap-panel-ng

Other

  • Add option HTTP_BINDING_ADDRESS to control the bound IP address (#665 by dyxyl)
  • Docker image: Pre-install Grafana plugins
  • Drop unused indexes

Bug Fixes

  • Fix an issue that could cause a missed firmware update not to be logged retroactively
  • Fix an issue where the vehicle process could crash when logging was suspended manually
  • Improve error message for an invalid tokens table
  • Fix min. distance per drive on Efficiency dashboard to filter correctly in miles (#672 by Dulanic)

1.19.2 - 2020-04-26

Enhancements

Translations

Dashboards

  • Updates: Show update duration and time since last update (#632 by Dulanic)
  • Charging Stats: Show kWh at non-decimal level and MWh at the 3 decimal point level (#642 and #646 by Dulanic)

Bug Fixes

  • Do not publish NULL or incorrect values to MQTT topics if TeslaMate is restarted while the car is asleep

1.19.1 - 2020-04-20

Enhancements

Translations

Bug Fixes

  • Fix an issue where the map tiles would disappear when editing a geofence
  • Fix a few things in the docs (#611 by tobiasehlert)

1.19.0 - 2020-04-19

Enhancements

Streaming API

As the first and only Tesla logging app out there, TeslaMate now use the Tesla streaming API! This brings the following improvements:

  • High precision drive data. Rather than active polling, the streaming API allows for passive consumption of a high frequency data stream with the most important drive data (position, heading, speed, power, elevation etc.).
  • Actual elevation above sea level. Up until now TeslaMate used satellite terrain data to get the elevation. Driving through tunnels or across a bridges therefore resulted in inaccurate recordings. This is no longer the case!
  • Bluetooth hints are no longer needed! Using the streaming API does not prevent the vehicle from falling asleep, thus enabling continuous monitoring. This allows the car to fall asleep more quickly (no more idle timer) and we don't miss up to 21 minutes of driving because of halted polling.

Many thanks to everyone who participated in testing this release and contributed improvements!

Translations

Other enhancements:

  • Send credentials with manifest request (#555 by MaxG88)
  • Add option to change the language of the web interface
  • Reduce docker image size
  • Display an arrow instead of a generic marker to indicate in which direction the vehicle is heading
  • Show spinner before the map is initialized
  • Wait until the doors/trunk/frunk are closed before attempting to fall asleep
  • Inform if a new TeslaMate update is available
  • Add icons to navbar items
  • Add 'About' section to the settings page
  • Publish only those values via MQTT that have actually changed
  • Improve detection of available vehicle software updates

New MQTT Topics

  • teslamate/cars/$car_id/elevation
  • teslamate/cars/$car_id/trunk_open
  • teslamate/cars/$car_id/frunk_open

Documentation

The docs were revised (once again). You can find them at docs.teslamate.org.

Bug Fixes

  • Display vampire drain range loss per hour in the correct units (#543 by ograff).
  • Trip dashboard: Add title to the drives table to allow sorting (#592 by MaxG88)
  • Add tini as the init process for the TeslaMate Docker container to avoid zombie processes (#606 by dbussink)
  • Sort "Drives" table properly by drive date (#595 by Dulanic)
  • Fix flashing modal on the geofence page
  • Publish an MQTT message when the health check succeeds again
  • Handle various invalid API responses that could previously cause problems
  • Fix an issue where ambiguous dates could cause the TeslaFi import to fail
  • Terminate an in progress drive when the car is put into service mode

Changed

  • Increase the minimum Elixir version to 1.10

Removed

  • Remove sleep mode requirements that are no longer needed
  • Remove option to disable sleep mode

1.18.2 - 2020-03-28

Bug Fixes

  • Fix an issue that could cause charging sessions not to be properly recorded if the API reported incomplete charge data
  • Fix a problem that could cause the TeslaFi import to fail

1.18.1 - 2020-03-23

Bug Fixes

1.18.0 - 2020-03-21

Enhancements

  • Add Swedish translation (#485 and #522 by tobiasehlert)
  • Add Norwegian translation (#500 by spacecosmos)
  • Add Spanish translation (#519 by alceasan)
  • Overview: Add states panel (#520 by DrMichael)
  • Immediately display the current car software version after restarting TeslaMate
  • Add mileage to the summary page
  • Add option to calculate charging costs retroactively
  • Allow to enter total cost or cost per KWh used
  • Indicate if any of the doors are open
  • Add support for session fees
  • Store more vehicle config attributes (exterior_color, wheel_type, spoiler_type)
  • Bump Grafana to 6.7.1

New MQTT Topics

  • teslamate/cars/$car_id/doors_open
  • teslamate/cars/$car_id/model
  • teslamate/cars/$car_id/trim_badging
  • teslamate/cars/$car_id/exterior_color
  • teslamate/cars/$car_id/wheel_type
  • teslamate/cars/$car_id/spoiler_type

Bug Fixes

  • Drive Stats: Show stats in desired units (#484 by pichalite)
  • Drive Details: Fix odometer units (#487 by pichalite)
  • Update address formatting to avoid showing obscure names instead of towns/cities
  • Charge Details: Hide empty series
  • Suppress Cldr.NoMatchingLocale warnings
  • Trip: Prevent 'division by zero' error
  • Open dashboard links in a new tab to work around Grafana regression
  • Use the maximum kWh to calculate the charge cost

1.17.1 - 2020-02-23

Bug Fixes

  • Fix an error that could prevent new users from logging in, among other things
  • Overview dashboard: Display odometer in desired units

1.17.0 - 2020-02-23

Enhancements

olexs has developed a toolkit to export data from the tesla-apiscraper InfluxDB backend and convert it to a CSV format that can be imported using the TeslaFi Import. Check it out if you want to migrate data to TeslaMate: Import from tesla-apiscraper (BETA)

  • Simplify geofence editing: The radius can now be changed interactively.
  • Allow geofences to overlap: If multiple geofences cover a position, the geofence whose centre is closest is selected.
  • Increase charge cost scale / kWh (#440 by baylanger)
  • Charge cost view: Show zoom controls
  • TeslaFi Import: Preselect the timezone
  • Add configuration option DATABASE_SSL
  • Use 'rated' as default preferred range
  • Collapse 'Dashboards' dropdown on mobile

Dashboards

  • Add Trip dashboard: This dashboard was built to visualize longer trips. It provides an overview of all drives and charges that were logged over a period of several hours or days.
  • All: Link to the web interface and other dashboards
  • Overview: Speed up database queries
  • Charges: Add geofence filter
  • Charge Details: Add cost overview (#460 by Niek)
  • Drive Details: Add usable battery level graph

New MQTT Topics

  • teslamate/cars/$car_id/geofence: The name of the geofence at the current position

Documentation

  • Add docs for tesla-apiscraper import (#454 by olexs)
  • Update Backup & Restore docs (#438 by AlwindB)
  • Revamp manual install docs

Bug Fixes

  • Fix an issue where some CSV files could not be imported

1.16.0 - 2020-02-07

Enhancements

  • Import from TeslaFi (BETA)
  • Calculate charge cost based on location and kWh
  • Automatically set charge cost to zero if free supercharging is enabled (configurable on the settings page)
  • Add French translation (#397 by tomS3210)
  • Improve language detection
  • Show odometer on 'Drive Details' dashboard
  • Bump Grafana to 6.6.1
  • Bump Elixir to 1.10

Documentation

  • New FAQ entry for adding API tokens directly into the database instead of using username/password (#412 by wishbone1138)
  • Improve standalone install documentation (#416 by Niek)
  • Improve iOS Shortcuts guide (#405 by DP19)

Bug Fixes

  • Re-add charge annotations to the 'Projected Range' dashboard (#393 by ctraber)
  • Correct typos in projected-range.json (#395 by shagberg)
  • Increase height of the pie charts panels
  • Address an issue where a drive would not be properly completed if the vehicle was suddenly reported as asleep after being offline for a while
  • Fix energy used in 'Drive Details'

1.15.1 - 2020-01-25

Enhancements

  • Tweak polling intervals
  • Make the web interface feel snappier

Bug Fixes

  • Fix an issue where distance, energy used and duration were missing on the Drive Details dashboard if the length unit was set to miles

1.15.0 - 2020-01-23

Enhancements

  • Add charge cost interface
  • Display usable SOC and show snowflake icon on summary page (#338 by ctraber)
  • Log missed software updates
  • Add tooltip with the estimated range at 100%
  • Remove software version commit hash
  • Format remaining charge time
  • Add option to use a custom namespace for MQTT topics
  • Periodically store vehicle data while online
  • Use the Accept-Language HTTP header get the locale (Supported languages: English, German)
  • Add setting to change the preferred language of OpenStreetMap results
  • Show spinner while fetching vehicle data
  • Add dropdown with dashboard links to the navigation bar

New MQTT Topics

  • teslamate/cars/$car_id/usable_battery_level

Dashboards

  • Projected Range: Use usable_battery_level to calculate the projected range and add more panels (#338, #367 by ctraber)
  • Add tesla tag (#369 by TechForze)
  • Vampire Drain: show SOC difference and ❄ (reduced range)
  • Charging Stats: Show share of AC/DC charging
  • Charging Stats: Show top charging stations by cost
  • Overview dashboard: Use the preferred range
  • Overview dashboard: Always show latest voltage and power while charging
  • Add Charge Level dashboard
  • Add Drive Stats dashboard
  • Revamp Drives/Drive Details and Charges/Charge Details dashboards

Documentation

  • Add docs for an advanced Docker install with Apache2 (#361 by DrMichael)
  • Add docs for backup and restore (#361 by DrMichael)
  • Update the macrodroid docs (#359 by markusdd)
  • Add docs for manually fixing data
  • Add docs for updating Postgres

Bug Fixes

  • Fix tooltips in Safari (iOS)
  • Always publish the shift state via MQTT
  • Fix an issue where he charge location was not be displayed
  • Fix an issue that could cause the added charge kWh to be shown as 0

⚠️ Please note: Due to internal changes, all addresses will be recalculated on first startup. Depending on the amount of data, this process may take up to 30 minutes or longer.

1.14.3 - 2020-01-06

Enhancements

  • Locations dashboard: Visualize cities and states with the most stored addresses

Bug Fixes

  • Fix an issue where a broken rear window sensor could cause the windows to always be displayed as open
  • Address an issue where a charge wouldn't be properly logged if the Tesla API reported invalid charge data
  • Fix a bug that could cause the geo-fence form to become unresponsive

1.14.2 - 2020-01-03

Bug Fixes

  • Fix an issue where invalid or revoked tokens could cause the application to crash after startup
  • Change default time range in the 'Updates' dashboard

1.14.1 - 2019-12-24

Bug Fixes

  • Fix an issue where the database migrations would not succeed if there were charges without any data points

1.14.0 - 2019-12-22

Enhancements

Documentation

@gundalow has revamped the docs (#292, #314). The new documentation is available here: teslamate.readthedocs.io

Automatic phase correction

The phase correction is now applied automatically.

Background: some vehicles incorrectly report 2 instead of 1 or 3 phases when charging. This led to an incorrect calculation of the 'kWh used'. Furthermore, the calculation did not work reliably in three-phase networks with e.g. 127/220V. Therefore it was necessary in the past to manually activate a phase correction for specific geo-fences. With this update the correction is now applied automatically.

Other enhancements

  • Refactored API module
  • Increased polling frequency in asleep state
  • New OSM aliases
  • ... and other minor improvements

Bug Fixes

  • Efficiency Dashboard: convert km/h to mph in the temperature efficiency table
  • Fix an issue where the application could crash because the database pool was too small
  • Fix an issue where a drive/charge could be split into two parts due to API timeouts

1.13.2 - 2019-12-07

Enhancements

  • Enable the time range control in the "Charging Stats" dashboard (#278 by @nnoally)
  • Various docs improvements (#285 by @gundalow)

Bug Fixes

  • Fix issue where on a brand new installation suspending logging would only work after a restart
  • Fix the elevation scale in the Drive Details

1.13.1 - 2019-11-26

Enhancements

Add a database column that will allow tracking charge costs:

  • Merge 20191117042320_add_cost_field_to_charges.exs (Charge Cost field) (#258 by @ngardiner)
  • Grafana Dashboard Integration for Charge Cost (#273 by @ngardiner)

Note: There is no charging cost interface either manual or automatic at this point but there will be in the future.

Bug Fixes

  • Downgrade the Grafana docker image to v6.3.7 because there are still issues with ARM-compatible images
  • Fix an issue where the selected car was not displayed when opening the drive or charging details

1.13.0 - 2019-11-25

New Features

  • Display link "Dashboards" inside the navigation bar (it becomes visible after clicking an address in one of the Grafana dashboards. Alternatively the Grafana URL can be added manually on the settings page)
  • Enable or disable the sleep mode depending on the location. For example, the car can be allowed to sleep at home or work, but nowhere else.
  • Extend Charge Stats Dashboard with discharge stats, a charge delta graph and a charge heatmap (#270 by @marcogabriel)

Enhancements

  • Make sleep mode separately configurable for each car
  • Reduce default "Time to try sleeping" to 12 minutes for newer vehicles
  • The "States" dashboard now includes software updates
  • Automatically repair trips and charges with missing addresses (e.g. because OpenStreetMap was temporarily unavailable)
  • Update thresholds of the battery level gauge (#256 by @marcogabriel)

Bug Fixes

  • Fix issue where consumption values were displayed as 0
  • Fix issue where installing a software update when charging would produce an incomplete charge record

1.12.2 - 2019-11-06

Bug Fixes

  • Fix an issue where the "states" graph would not show every drive/charge
  • Fix an issue where the application would not start if the vehicle was parked at a place with poor reception
  • Remove duplicate table row "Remaining Time"

1.12.1 - 2019-11-03

Enhancements

  • Display remaining time while charging

New MQTT Topics

  • teslamate/cars/$car_id/heading

Bug Fixes

  • Consistent language for label of charging events (#299)
  • Cap charging efficiency to 100%

1.12.0 - 2019-10-28

We finally have documentation! Many thanks to @ngardiner, who gave the impulse and did most of the work and also to @krezac, who contributed a guide to creating iOS Shortcuts for TeslaMate!

New Features

Vehicle Efficiency

Previous versions of TeslaMate shipped with hard-coded efficiency values for the various Tesla models. These efficiency values are needed to calculate trip consumptions, because the Tesla API does not provide them directly.

The hard-coded values were probably pretty accurate, but it was impossible to ensure the correctness of all of them. In addition, the new Model S and X "Raven" could not be reliably identified because the Tesla API returns wrong option codes for both.

This version eliminates the need to use these hard-coded values and instead calculates them based on the recorded charging data. It takes at least two charges to display the first estimate. Each subsequent charge will then continue to improve the accuracy of the estimate, which is applied retroactively to all data.

Charge energy used

In addition to the kWh added to the battery during the charge TeslaMate now calculates the actual energy used by the charger, which in most cases is higher than the energy added to the battery.

Consider this feature somewhat experimental. Theoretically, however, it should be pretty accurate as long as the vehicle has a stable internet connection while charging (other paid Tesla loggers use the same calculation method).

Currently, a firmware bug in some vehicles may cause the wrong number of phases to be reported when charging at some chargers. As a workaround, a phase correction can be activated per geo-fence.

New MQTT Topics

  • teslamate/cars/$car_id/update_available
  • teslamate/cars/$car_id/is_climate_on
  • teslamate/cars/$car_id/is_preconditioning
  • teslamate/cars/$car_id/is_user_present

Enhancements

  • Show icon indicators for various states (sentry mode, vehicle locked, windows open, pre-conditioning etc.)
  • Various UI Tweaks
  • Grafana: show the precise duration of a trip in a tooltip
  • Serve gzipped assets
  • Disable origin check by default to simplify the installation of TeslaMate. (⚠️ For publicly exposed TeslaMate instances it is advisable to re-enable the check by adding the environment variable CHECK_ORIGIN=true.)

Bug Fixes

  • Set the correct end date for charges where the vehicle remains plugged in after completion
  • Fix an issue with vehicles that were removed from the Tesla Account
  • Correctly handle API responses which indicate that the vehicle is in service
  • Display effects of range gains (e.g. from supercharging pre-conditioning a cold battery) as NULL

1.11.1 - 2019-10-13

Bug Fixes

  • Show all cars in the Overview dashboard

1.11.0 - 2019-10-12

New Features

  • Add overview dashboard (by DBemis; #196)
  • Make :check_origin option configurable via environment variable CHECK_ORIGIN
  • Open GitHub release page when clicking the version tag in the navbar
  • Display the current software version

New MQTT topics

  • teslamate/cars/$car_id/version: Current software version

Enhancements

  • Tweak the mobile and desktop views
  • Add GIST index based on ll_to_earth to speed up geo-fence lookups
  • Improve accuracy of geo-fence lookups for some edge cases
  • Log option codes as well if the vehicle identification fails
  • Delete trips with less than 10m driven
  • Add/Update efficiency factors

Bug Fixes

  • Fix an issue where postgres' automatic analyze couldn't succeed
  • Fix an issue where the derived efficiency factors could not be calculated
  • Exit early if migrations fail
  • Downgrade Grafana to v6.3.5

1.10.0 - 2019-10-05

Enhancements

  • Allow editing of geo-fence positions
  • Show warning icon if the health check fails for a vehicle
  • Use the best available SRTM data source which provides global elevation data including 60N and above
  • Optimize the comparison of geo-fences by moving the lookup into the database
  • Use the exact position instead of the center of an address for the geo-fence lookup
  • Generally improve error handling and error messages
  • Improve landscape mode on devices with a notch
  • Open the geo-fence editor by clicking on the start or destination address of a trip

    Note: For this feature to work Grafana needs to know the base URL of the TeslaMate web interface. To automatically set the base URL open the web interface once after upgrading to this version. Manually changing the base URL is possible via the settings page.

New MQTT topics

  • teslamate/cars/$car_id/healthy: Reports the health status of the logger
  • teslamate/cars/$car_id/windows_open
  • teslamate/cars/$car_id/shift_state
  • teslamate/cars/$car_id/latitude
  • teslamate/cars/$car_id/longitude
  • teslamate/cars/$car_id/odometer
  • teslamate/cars/$car_id/charge_port_door_open
  • teslamate/cars/$car_id/charger_actual_current
  • teslamate/cars/$car_id/charger_phases
  • teslamate/cars/$car_id/charger_power
  • teslamate/cars/$car_id/charger_voltage
  • teslamate/cars/$car_id/time_to_full_charge

Bug Fixes

  • Automatically restart parts of the application if Tesla decides yet again to change the IDs of some vehicles
  • Request to sign in again if the access tokens become invalid e.g. because the password of the Tesla Account has been changed
  • Protect against empty payloads during an update to prevent an update from not being fully logged
  • Log the number of charging phases as returned by the API

⚠️ Running Migrations

Users of the default docker-compose.yml can skip this part.

To run the migrations successfully, the database user has to have superuser rights (temporarily):

  • To add superuser rights: ALTER USER teslamate WITH SUPERUSER;
  • To remove superuser rights: ALTER USER teslamate WITH NOSUPERUSER;

1.9.1 - 2019-09-24

Fixed

  • Set position when selecting a search entry
  • Fix deletion of geo-fences

1.9.0 - 2019-09-24

Added

  • Show a map with the current vehicle position on the web interface
  • Add a satellite/hybrid layer to the geo-fence map
  • Use elevation data with 1 arc second (~30m) accuracy everywhere not just in the US
  • Add support for MQTT SSL (#140)
  • Add "Charged" annotation to the degradation dashboard
  • Add preferred range setting: you can now choose between "ideal" and "rated" range to use as the basis for efficiency and other metrics

Changed

  • Require a data source named "TeslaMate":

    If you don't run the teslamate/grafana docker container the Grafana data source has to have the name "TeslaMate". Prior to this change the default data source was used.

  • Renamed the MQTT topic teslamate/cars/$car_id/battery_range_km to teslamate/cars/$car_id/rated_battery_range_km.

Fixed

  • Prevent suspending when an update is in progress
  • Fix charge counter when using with multi vehicles (#175)

Removed

  • Drop support for the deprecated env variables TESLA_USERNAME and TESLA_PASSWORD

1.8.0 - 2019-09-03

Added

  • Identify cars by VIN: This hopefully eliminates any upcoming problems when Tesla decides yet again to change the IDs of their cars ...
  • Pick geo-fences from a map and show their radius

Fixed

  • Only add elevation to positions for which SRTM elevation data is available
  • [Security] Bump Grafana version

1.7.0 - 2019-08-29

Added

  • Locally (!) query all locations for elevation data from the NASA Shuttle Radar Topography Mission (SRTM)

  • Add elevation graph to the Drive Details dashboard

  • Display rated range on the web interface and on the Drive Details dashboard

  • Switch to the vehicle_config API endpoint to identify vehicles

  • Display the default and derived efficiency factor on the Efficiency dashboard to detect inaccuracies and to crowdsource the correct factors:

    Note: If there is no default efficiency factor or you think the default factor for your vehicle might be wrong, please open an issue and attach a screenshot of the table showing the efficiency factor(s) for your vehicle.

  • Display charger power on the web interface

Fixed

  • Fix calculation of charge_energy_added if a previously stopped charge session is resumed

1.6.2 - 2019-08-26

Fixed

  • Fix migration that could panic when upgrading from v1.4 to v1.6
  • Fix efficiency calculation

1.6.1 - 2019-08-25

Added

  • Add separately configurable sleep requirements

Fixed

  • Improve identification of performance models
  • Fix Model X identification
  • Improve browser compatibility of the web interface
  • Disable basic auth in Grafana
  • Remove pre-calculated consumption columns and instead calculate consumption values dynamically based on the given efficiency factor
  • Add various database constraints to keep data in a consistent state

1.6.0 - 2019-08-18

Added / Changed

Dashboards

  • Display car name instead of its id and replace dropdown with separate row for each car
  • Improve States dashboard:
    • show state names instead of arbitrary numbers
    • include drives and charge sessions
  • Vampire Drain: include offline state when calculating the standby value
  • Drive Details: add estimated range graph
  • Degradation: Increase resolution of projected 100% range

Web UI

  • Add favicons
  • Fetch last known values from database after (re)starting TeslaMate
  • Show duration of current state
  • Show estimated range
  • Hide stale temperature data
  • Hide some metrics when they're not needed

Fixed

  • Interpret a significant offline period with SOC gains as a charge session
  • Timeout drive after being offline for too long
  • Dashboards: Dynamically calculate consumption values based on stored car.efficiency

1.5.3 - 2019-08-14

Fixed

  • Add extra values to the "Time to Try Sleeping" dropdown

  • Rollback the "Time to Try Sleeping" setting to previous pre v1.5 value (21 min) to play it safe

    Note to Model 3 owners and everyone who likes to tweak things a bit: most cars seem to handle a value of 12min just fine. Doing so reduces the likelihood of potential data gaps. Just keep an eye on your car afterwards to see if it still goes into sleep mode.

  • Enable filtering of charges by date

  • Fix charges query to include the very first charge

1.5.2 - 2019-08-13

Fixed

  • Fix migration that could panic if upgrading from <v1.4.3 to v1.5

1.5.1 - 2019-08-13

Fixed

  • Remove shift_state condition which could prevent some cars from falling asleep

1.5.0 - 2019-08-12

Added

  • Add geo-fence feature
  • Make units of length and temperature separately configurable
  • Make time to try sleeping and idle time before trying to sleep configurable
  • Show buttons try to sleep and cancel sleep attempt on status screen if possible
  • Add charging stats: charged in total, total number of charges, top charging stations

Changed

  • Reduce time to try sleeping from 21 to 12 minutes
  • Increase test coverage
  • Rename some dashboards / panels

Fixed

  • Add order by clause to degradation query
  • Read LOCALE at runtime

1.4

1. New custom grafana image: teslamate/grafana

Starting with this release there is a customized Grafana docker image (teslamate/grafana) that auto provisions the datasource and dashboards which makes upgrading a breeze! I strongly recommend to use it instead of manually re-importing dashboards.

Just replace the grafana service in your docker-compose.yml:

  # ...

  grafana:
    image: teslamate/grafana:latest
    environment:
      - DATABASE_USER=teslamate
      - DATABASE_PASS=secret
      - DATABASE_NAME=teslamate
      - DATABASE_HOST=db
    ports:
      - 3000:3000
    volumes:
      - teslamate-grafana-data:/var/lib/grafana

  # ...

And add a new volume at the bottom of the file:

volumes:
    # ...
    teslamate-grafana-data:
    # ...

Find the full example in the updated README.

2. Switch to imperial units

There is a new settings view in the web interface. To use imperial measurements in grafana and on the status screen just tick the checkbox it shows!

3. Deprecation of TESLA_USERNAME and TESLA_PASSWORD

With this release API tokens are stored in the database. After starting TeslaMate v1.4 once, you can safely remove both environment variables.

New users need to sign in via the web interface.

Full Changelog:

1.4.3 - 2019-08-05

Added

  • Status screen: show additional charging related information

  • MQTT: add new topics

    teslamate/cars/$car_id/plugged_in
    teslamate/cars/$car_id/scheduled_charging_start_time
    teslamate/cars/$car_id/charge_limit_soc
    

Fixed

  • Fix an issue where charging processes were not completed and new charging processes were created after waking up from sleep mode while still plugged in to a charger.

  • Add migration to fix incomplete charging processes

  • Use local time in debug logs:

    Add a TZ variable with your local timezone name to the environment of the teslamate container. Otherwise timestamps use UTC.

  • Charging History: hide entries with 0kWh charge energy added

  • Charging History: include current car-id in links to Charging dashboard

  • Charging History: use slightly earlier start date in links to Charging dashboard to always show the current position

1.4.2 - 2019-08-01

Fixed

  • Persists tokens after auto refresh

1.4.1 - 2019-07-31

Fixed

  • Convert to imperial measurements on status screen
  • Fix warnings

1.4.0 - 2019-07-31

Dashboards

Added

  • Introduce custom teslamate/grafana Docker image
  • Fetch unit variables from database

Fixed

  • Fix syntax errors in consumption and charging dashboard
  • The consumption and charging dashboards can now be viewed without having to select a drive / charging process first.

Removed

  • The German dashboard translations have been removed. It was too time consuming to keep everything up to date.

TeslaMate

Added

  • Show version on web UI
  • Persist API tokens
  • Add sign in view
  • Add settings view

Changed

  • Log :car_id

Fixed

  • Fix generation of secret_key_base

1.3.0 - 2019-07-29

Changed

  • Fix / inverse efficiency calculation: if distance traveled is less than the ideal rated distance the efficiency will now be lower than 100% and vice-versa.

    Important: re-import the Grafana Dashboards (en_efficiency & en_trips) after restarting TeslaMate

1.2.0 - 2019-07-29

Added

  • Add psql conversion helper functions (via database migration)

  • Report imperial metrics

    Important: please re-import the Grafana Dashboards after restarting TeslaMate

Fixed

  • Remove TZ environment variable from Dockerfile

1.1.1 - 2019-07-27

Changed

  • Upgrade tesla_api
  • Upgrade Phoenix LiveView

Fixed

  • Fix a few english translations in the en dashboards
  • Remove DATABASE_PORT from docker-compose example
  • Remove port mapping from postgres in docker-compose example
  • Extend FAQ

1.1.0 - 2019-07-27

Added

  • Support custom database port through DATABASE_PORT environment variable
  • Add entrypoint to handle db migration

Changed

  • Replace node-sass with sass to speed up compilation

Fixed

  • Update README.md to fix resume and suspend logging PUT requests.

1.0.1 - 2019-07-26

Changed

  • Set unique :id to support multiple vehicles
  • Reduce default pool size to 5
  • Install python in the builder stage to build on ARM
  • Increase timeout used on assert_receive calls

1.0.0 - 2019-07-25