Skip to main content

Asynchronous Python client for Salus IT600 devices

Project description

Python: Asynchronous client for Salus iT600 devices

For end users

See https://github.com/jvitkauskas/homeassistant_salus to use this in Home Assistant.

About

This package allows you to control and monitor your Salus iT600 smart home devices locally through Salus UG600 universal gateway. Currently heating thermostats, binary sensors, temperature sensors, covers and switches are supported. You have any other devices and would like to contribute - you are welcome to create an issue or submit a pull request.

Installation

pip install pyit600

Usage

  • Instantiate the IT600Gateway device with local ip address and EUID of your gateway. You can find EUID written down on the bottom of your gateway (eg. 001E5E0D32906128).
  • Status can be polled using the poll_status() command.
  • Callbacks to be notified of state updates can be added with the add_climate_update_callback(method) or add_sensor_update_callback(method) method.

Basic example

async with IT600Gateway(host=args.host, euid=args.euid) as gateway:
	await gateway.connect()
	await gateway.poll_status()

	climate_devices = gateway.get_climate_devices()

	print("All climate devices:")
	print(repr(climate_devices))

	for climate_device_id in climate_devices:
		print(f"Climate device {climate_device_id} status:")
		print(repr(climate_devices.get(climate_device_id)))

		print(f"Setting heating device {climate_device_id} temperature to 21 degrees celsius")
		await gateway.set_climate_device_temperature(climate_device_id, 21)

Useful gateway methods

  • poll_status()
  • get_climate_devices()
  • get_climate_device(device_id)
  • set_climate_device_preset(device_id, preset)
  • set_climate_device_mode(device_id, mode)
  • set_climate_device_temperature(device_id, setpoint_celsius)
  • get_binary_sensor_devices()
  • get_binary_sensor_device(device_id)
  • get_switch_devices()
  • get_switch_device(device_id)
  • turn_on_switch_device(device_id)
  • turn_off_switch_device(device_id)
  • get_cover_devices()
  • get_cover_device(device_id)
  • set_cover_position(device_id, position)
  • open_cover(device_id)
  • close_cover(device_id)
  • get_sensor_devices()
  • get_sensor_device(device_id)
  • get_gateway_device()

Supported devices

These thermostats have been tested:

  • HTRP-RF(50)
  • TS600
  • VS10WRF/VS10BRF
  • VS20WRF/VS20BRF
  • SQ610RF

These binary sensors have been tested:

  • SW600

These binary sensors have not been tested, but may work:

  • WLS600
  • OS600
  • SD600

These temperature sensors have been tested:

  • PS600

These switch devices have been tested:

  • SPE600
  • RS600

These switch devices have not been tested, but may work:

  • SR600
  • SP600

These cover devices have been tested:

  • RS600

Troubleshooting

Check if you have "Local Wifi Mode" enabled:

  • Open Smart Home app on your phone
  • Sign in
  • Double tap your Gateway to open info screen
  • Press gear icon to enter configuration
  • Scroll down a bit and check if "Disable Local WiFi Mode" is set to "No"
  • Scroll all the way down and save settings
  • Restart Gateway by unplugging/plugging USB power

Contributing

If you want to help to get your device supported, open GitHub issue and add your device model number and output of main.py program. Be sure to run this program with --debug option.

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

pyit600-0.2.6.tar.gz (11.3 kB view details)

Uploaded Source

Built Distribution

pyit600-0.2.6-py3-none-any.whl (11.9 kB view details)

Uploaded Python 3

File details

Details for the file pyit600-0.2.6.tar.gz.

File metadata

  • Download URL: pyit600-0.2.6.tar.gz
  • Upload date:
  • Size: 11.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.8

File hashes

Hashes for pyit600-0.2.6.tar.gz
Algorithm Hash digest
SHA256 ad8a1828f2f28de91695da12d9274a10ae2c0af06dc5a8a008e8c86e188813aa
MD5 27d4938f2bf41bc4210c4c8b787c8908
BLAKE2b-256 71eceaf76be2259b598b10a90ba87761af559f609036291050e2ea10f6afe4e5

See more details on using hashes here.

File details

Details for the file pyit600-0.2.6-py3-none-any.whl.

File metadata

  • Download URL: pyit600-0.2.6-py3-none-any.whl
  • Upload date:
  • Size: 11.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.8

File hashes

Hashes for pyit600-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e5d9637568157872dc295c28cdba4a6490682e8b696ad2ec3d6223df9f0de18a
MD5 3f4846c40120be2cd62345ed501ce737
BLAKE2b-256 fa459719624f97478550a4dd77aeb29cd9dcdf8aef825176f36040c1b983e8fe

See more details on using hashes here.

Supported by

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