Skip to main content

devolo PLC devices in Python

Project description

devolo PLC API

GitHub Workflow Status PyPI - Downloads Code Climate maintainability Coverage Status

This project implements parts of the devolo PLC devices API in Python. Communication to the devices is formatted in protobuf and the IDLs were kindly provided by devolo. Nevertheless, we might miss updates to the IDLs. If you discover a breakage, please feel free to report an issue.

System requirements

Defining the system requirements with exact versions typically is difficult. But there is a tested environment:

  • Linux
  • Python 3.9.22
  • pip 25.0.1
  • ifaddr 0.2.0
  • httpx 0.28.1
  • protobuf 5.28.3
  • segno 1.6.1
  • tenacity 9.0.0
  • zeroconf 0.146.1

Other versions and even other operating systems might work. Feel free to tell us about your experience. If you want to run our unit tests, you also need:

  • pytest 7.4.4
  • pytest-asyncio 0.26.0
  • pytest-httpx 0.35.0
  • syrupy 4.9.1

Versioning

In our versioning we follow Semantic Versioning.

Installing for usage

The Python Package Index takes care for you. Just use pip.

pip install devolo-plc-api

Installing for development

First, you need to get the sources.

git clone git@github.com:2Fake/devolo_plc_api.git

Then you need to take care of the requirements.

cd devolo_plc_api
python setup.py install

If you want to run out tests, install the extra requirements and start pytest.

pip install -e .[test]
pytest

Usage

All features we currently support on device basis are shown in our examples. If you want to use the package asynchronously, please check example_async.py. If you want to use it synchronously, please check example_sync.py.

If you don't know the IP addresses of your devices, you can discover them. You will get a dictionary with the device's serial number as key. The connections to the devices will be already established, but you will have to take about disconnecting.

from devolo_plc_api.network import async_discover_network

devices = await async_discover_network()
await asyncio.gather(*[device.async_connect() for device in _devices.values()])
# Do your magic
await asyncio.gather(*[device.async_disconnect() for device in devices.values()])

Or in a synchronous setup:

from devolo_plc_api.network import discover_network

devices = discover_network()
for device in _devices.values():
        device.connect()
# Do your magic
[device.disconnect() for device in devices.values()]

Supported device

The following devolo devices were queried with at least one call to verify functionality:

  • Magic 2 WiFi next
  • Magic 2 WiFi 2-1
  • Magic 2 LAN triple
  • Magic 2 DinRail
  • Magic 2 LAN 1-1
  • Magic 1 WiFi mini
  • Magic 1 WiFi 2-1
  • Magic 1 LAN 1-1
  • Repeater 5400
  • Repeater 3000
  • Repeater 1200
  • Repeater ac+
  • Repeater ac
  • dLAN 1200+ WiFi ac
  • dLAN 550+ Wifi
  • dLAN 550 WiFi

However, other devices might work, some might have a limited functionality. Also firmware version will matter. If you discover something weird, we want to know.

Project details


Download files

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

Source Distribution

devolo_plc_api-1.5.1.tar.gz (63.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

devolo_plc_api-1.5.1-py3-none-any.whl (58.8 kB view details)

Uploaded Python 3

File details

Details for the file devolo_plc_api-1.5.1.tar.gz.

File metadata

  • Download URL: devolo_plc_api-1.5.1.tar.gz
  • Upload date:
  • Size: 63.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for devolo_plc_api-1.5.1.tar.gz
Algorithm Hash digest
SHA256 44864710d76315b7e0bd9e37c0949804b2e31dde27a815b3b47d8c6a43892fec
MD5 920a87affed526963d6391d2f02aff50
BLAKE2b-256 94df64bb31926f3ad7676781eb31d9c91b28bc1306ec0749099da1a9980a2534

See more details on using hashes here.

File details

Details for the file devolo_plc_api-1.5.1-py3-none-any.whl.

File metadata

  • Download URL: devolo_plc_api-1.5.1-py3-none-any.whl
  • Upload date:
  • Size: 58.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for devolo_plc_api-1.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ff97a93a2fec1cf2020b5fc0280702428def55a5ed815a49d9160788df7b47a8
MD5 e2c87030e5d154c88a909067dac95385
BLAKE2b-256 4132e5600216e1502946212f298222df69835fe43f7cd7b708f419e67eb6b3f1

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page