Skip to main content

A library for interfacing via the ECHONETlite protocol.

Project description

Pychonet

GitHub Release License Project Maintenance

A library for interfacing with the ECHONETlite protocol as commonly used in Japan. Useful for interfacing to many interesting devices such as HVACs, light systems, electric car chargers, rice cookers (not joking), and solar systems that support ECHONETLite.

The current functionality is limited to a few ECHONETLite classes, notably HVAC but it can easily be extended to any ECHONETlite classes required.

The basic boilerplate EchoNetInstance class can be used to provide raw connectivity to any compatible device but it is up to the developer to create useful classes. Any ECHONETlite class additions to the library are welcome.

Version 2.0.0 of this library was rebuilt to use asyncio for better compatability with home assistant.

It is designed to work with Python 3.9.5+

Instructions

Simplest way to install is to use pip:

pip install pychonet

Basic usage

Create the ECHONETLite listener service on port 3610:

from pychonet.lib.udpserver import UDPServer
from pychonet import Factory
from pychonet import ECHONETAPIClient as api
from pychonet import HomeAirConditioner
from pychonet import EchonetInstance
udp = UDPServer()
loop = asyncio.get_event_loop()
udp.run("0.0.0.0", 3610, loop=loop)
server = api(server=udp)

Discover a list of ECHONETlite instances on a particular server:

await server.discover('192.168.1.6')

Populate the propertymap for a particular ECHONETLite instance:

await server.getAllPropertyMaps('192.168.1.6', 1, 48, 1)

Create a ECHONETLite device using the Factory:

Paramaters include the port listener, and EOJGC, EOJCC, and EOJCI codes.

aircon = Factory("192.168.1.6",server, 1, 48, 1)

OR, create a specific ECHONETLite instance using built in objects:

aircon = HomeAirConditioner("192.168.1.6", server)

Turn HVAC on or off:

await aircon.on()
await aircon.off()
await aircon.getOperationalStatus()
{'status': 'off'}

Set or Get a HVACs target temperature:

await aircon.setOperationalTemperature(25)
await aircon.getOperationalTemperature()
{'set_temperature': 25}

Set or Get a HVACs mode of operation:

supported modes =  'auto', 'cool', 'heat', 'dry', 'fan_only', 'other'

await aircon.setMode('cool')
await aircon.getMode()
{'mode': 'cool'}

Set or Get a HVACs fan speed:

Note - your HVAC may not support all fan speeds.

supported modes = 'auto', 'minimum', 'low', 'medium-Low', 'medium', 'medium-high', 'high', 'very high', 'max'

await aircon.setFanSpeed('medium-high')
await aircon.getFanSpeed()
{'fan_speed': 'medium-high'}

Get HVAC attributes at once (Note, the property map must be populated):

await aircon.update()
{'status': 'On', 'set_temperature': 25, 'fan_speed': 'medium-high', 'room_temperature': 25, 'mode': 'cooling'}

OR grab a specific attribute at once (Note, the property map must be populated):

await aircon.update(0x80)

Using this library with Home Assistant

NOTE: For Home Assistant users there is a dedicated repo that can be installed via HACS that can provide custom components for discovered ECHONETlite devices such as Mitsubishi airconditioners: (https://github.com/scottyphillips/echonetlite_homeassistant)

'example_async.py' gives you a boilerplate asyncio program that will discover your ECHONETLite instance and return information about supported services.

Hall of Fame

Big Thanks to Naoki Sawada for many excellent updates to enable push notifications via multicast. どうもありがとうございます !

Thanks to Jason Nader for all the quality of life updates to the codebase and doco.

Thanks to khcnz (Karl Chaffey) and gvs for helping refector the old code and contributing to testing.

Thanks to Dick Swart, Masaki Tagawa, Paul, khcnz, Kolodnerd, Leonunix, and Alfie Gerner for each contributing code updates to this library.

Thanks to Jeffro Carr who inspired me to write my own native Python ECHONET library for Home Assistant.

Thanks to Futomi Hatano for open sourcing a well-documented ECHONET Lite library in Node JS. (https://github.com/futomi/node-echonet-lite)

References for ECHONET specifications

License

This application is licensed under an MIT license, refer to LICENSE-MIT for details.

Portions of 'ECHONET Lite Device Emulator' (Copyright 2020 Kanagawa Institute of Technology) have been used in this application. This code was licensed under the MIT licence.

The UDP code is based on 'aio-udp-server' (Copyright 2021 Dmitriy Bashkirtsev) This code is licenced under the GPL licence. (https://github.com/bashkirtsevich-llc/aioudp)

Слава Україні! 🇺🇦


Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pychonet-2.6.18.tar.gz (72.9 kB view details)

Uploaded Source

Built Distribution

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

pychonet-2.6.18-py3-none-any.whl (85.3 kB view details)

Uploaded Python 3

File details

Details for the file pychonet-2.6.18.tar.gz.

File metadata

  • Download URL: pychonet-2.6.18.tar.gz
  • Upload date:
  • Size: 72.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.8.3

File hashes

Hashes for pychonet-2.6.18.tar.gz
Algorithm Hash digest
SHA256 641851f2d618d33e92de76b528c0d6655f4ba173cded60b7f6c099a42e3e4791
MD5 406eada8f7b7adf3f188e5a5ccbd66e7
BLAKE2b-256 726ac81c590bbc4a7764fccbbae83dec3a34a7e08f7238f8daea032bd22b413c

See more details on using hashes here.

File details

Details for the file pychonet-2.6.18-py3-none-any.whl.

File metadata

  • Download URL: pychonet-2.6.18-py3-none-any.whl
  • Upload date:
  • Size: 85.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.8.3

File hashes

Hashes for pychonet-2.6.18-py3-none-any.whl
Algorithm Hash digest
SHA256 956b6a66042883fbb313fc57f8a7d4e49ad811e481fdfe157dd7f93a45a6aef0
MD5 5f1933a1a3894d6508ef410f33df074d
BLAKE2b-256 3d334baf1a642a33960dcbc30f99a3c066f3bc1f64dafd38e3c74d06f4bf6967

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