Skip to main content

Library to read data from the BMW Connected Drive portal

Project description

This is a simple library to query and control the status of your BMW from the connected drive portal.

See bimmerconnected for usage instruction or the API Documentation.

I wrote this library as I want to include it in Home Assistant.


This works with BMW vehicles with a ConnectedDrive account. So far it is tested on vehicles with a ‘NBTEvo’, ‘EntryEvo’, ‘NBT’, or ‘EntryNav’ navigation system. If you have any trouble with other navigation systems, please create an issue with your server responses (see next section).

To use this library, your BMW must have the remote services enabled for your vehicle. You might need to book this in the Connected Drive portal and this might cost some money. In addition to that you need to enable the Remote Services in your infotainment system in the vehicle.

Different models of vehicles and infotainment systems result in different types of attributes provided by the server. So the experience with the library will certaily vary across the different vehicle models.

Data Contributions

If some features do not work for your vehicle, we would need the data returned form the server to analyse this and potentially extend the code. Different models and head unit generations lead to different responses from the server.

If you want to contribute your data, perform the following steps:

# get the latest version of the library
pip3 install --upgrade bimmer_connected

# run the fingerprint function
bimmerconnected fingerprint <username> <password> <region>

This will create a set of log files in the “vehicle_fingerprint” folder. Before sending the data to anyone please check for any personal data. The following attributes should be replaced with default values: * vin (=Vehicle Identification Number) * lat and lon (=GPS position) * licensePlate

Create a new issue in bimmer_connected and add the files as attachment to the issue.

Please add your model and year to the title of the issue, to make it easier to organize. If you know the “chassis code” of your car, you can include that too. (For example, Googling “2017 BMW X5” will show a Wikipedia article entitled “BMW X5 (F15)”. F15 is therefore the chassis code of the car.)

Note: We will then use this data as additional test cases. So we will publish (parts of) it (after checking for personal information again) and use this as test cases for our library. If you do not want this, please let us know in advance.

Code Contributions

Contributions are welcome! Please make sure that your code passed the “tox” checks. And please add tests where it makes sense. The more the better.

Thank you

Thank you @gerard33, @m1n3rva, @kernelkraut, @robbz23, @lawtancool for your research and contributions!

This library is basically a best-of of other similar solutions I found, yet none of them provided a ready to use library with a matching interface to be used in Home Assistant and is available on pypi.

Thank you for your great software!


The bimmer_connected library is licensed under the Apache License 2.0.


This library is not affiliated with or endorsed by BMW Group.

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
bimmer_connected-0.5.3-py3-none-any.whl (26.4 kB) Copy SHA256 hash SHA256 Wheel py3
bimmer_connected-0.5.3.tar.gz (22.3 kB) Copy SHA256 hash SHA256 Source None

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page