A Python module that emulates a virtual IQ Remote device, enabling full local control of a Qolsys IQ Panel
Project description
Qolsys Controller - qolsys-controller
A Python module that emulates a virtual IQ Remote device, enabling full local control of a Qolsys IQ Panel over MQTT — no cloud access required.
QolsysController
- ✅ Connects directly to the Qolsys Panel's local MQTT server as an IQ Remote
- 🔐 Pairs by only using Installer Code (same procedure as standard IQ Remote pairing)
- 🔢 Supports 4-digit user codes
- ⚠️ Uses a custom local usercode database — panel's internal user code verification process is not yet supported
✨ Functionality Highlights
| Category | Feature | Status |
|---|---|---|
| Panel | Diagnostic Sensors | ✅ |
| Panel Scenes | ✅ | |
| Weather Forecast | ✅ | |
| (Alarm.com Weather to Panel) | ||
| Partition | Arming Status | ✅ |
| Alarm State | ✅ | |
| Home Instant Arming | ✅ | |
| Home Silent Disarming (Firmware 4.6.1) | ✅ | |
| Set Exit Sounds | ✅ | |
| Set Entry Delay | ✅ | |
| TTS | 🛠️ | |
| Zones | Sensor Status | ✅ |
| Tamper State | ✅ | |
| Battery Level | ✅ | |
| Temperature (supported PowerG device) | ✅ | |
| Light (supported PowerG device) | ✅ | |
| Average dBm | ✅ | |
| Latest dBm | ✅ | |
| Z-Wave Devices | Battery Level | ✅ |
| Node Status | ✅ | |
| Control Generic Devices | TBD | |
| Z-Wave Dimmers | Binary Switch | ✅ |
| Multi Level Dimmer | ✅ | |
| Z-Wave Door Locks | Lock, Unlock | ✅ |
| Z-Wave Thermostats | Read device status | ✅ |
| Write device status | ✅ | |
| Z-Wave Garage Doors | 🛠️ | |
| Z-Wave Outlets | 🛠️ |
⚠️ Certificate Warning
During pairing, the main panel issues only one signed client certificate per virtual IQ Remote. If any key files are lost or deleted, re-pairing may become impossible.
A new PKI, including a new private key, can be recreated under specific circumstances, though the precise conditions remain unknown at this time.
Important:
Immediately back up the following files from the pki/ directory after initial pairing:
.key(private key).cer(certificate).csr(certificate signing request).secure(signed client certificate).qolsys(Qolsys Panel public certificate)
Store these files securely.
📦 Installation
git clone https://github.com/EHylands/QolsysController.git
cd qolsys_controller
pip3.12 install -r requirements.txt
# Change panel_ip and plugin_in in main.py file
python3.12 example.py
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file qolsys_controller-0.2.9.tar.gz.
File metadata
- Download URL: qolsys_controller-0.2.9.tar.gz
- Upload date:
- Size: 59.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c8ee06e77eb0d0014e07426d3ed2e49d3b73979e22b738f735bb544f49f12668
|
|
| MD5 |
333ea5f42db8127d9b1438142a6c13a2
|
|
| BLAKE2b-256 |
c7ffa719be18a3dee50c97b52a83fe1dfd5acef1a7b7adee67f7410017f0ca8b
|
Provenance
The following attestation bundles were made for qolsys_controller-0.2.9.tar.gz:
Publisher:
publish.yml on EHylands/QolsysController
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qolsys_controller-0.2.9.tar.gz -
Subject digest:
c8ee06e77eb0d0014e07426d3ed2e49d3b73979e22b738f735bb544f49f12668 - Sigstore transparency entry: 829711883
- Sigstore integration time:
-
Permalink:
EHylands/QolsysController@cdef14588dbdd37c9f5061ad97376e4829c2236d -
Branch / Tag:
refs/tags/v0.2.9 - Owner: https://github.com/EHylands
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@cdef14588dbdd37c9f5061ad97376e4829c2236d -
Trigger Event:
release
-
Statement type:
File details
Details for the file qolsys_controller-0.2.9-py3-none-any.whl.
File metadata
- Download URL: qolsys_controller-0.2.9-py3-none-any.whl
- Upload date:
- Size: 87.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
452cd0460c67f0936f8b92a311fa8992cb718b5c1a75512100cecbd5634c6821
|
|
| MD5 |
4d52cd2a29ed14a8029ec2153ef86761
|
|
| BLAKE2b-256 |
d6bbc51f32c48bc4fe0da41443ebe3a3db9117a8c4766eee3653a2203bf241ce
|
Provenance
The following attestation bundles were made for qolsys_controller-0.2.9-py3-none-any.whl:
Publisher:
publish.yml on EHylands/QolsysController
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qolsys_controller-0.2.9-py3-none-any.whl -
Subject digest:
452cd0460c67f0936f8b92a311fa8992cb718b5c1a75512100cecbd5634c6821 - Sigstore transparency entry: 829711887
- Sigstore integration time:
-
Permalink:
EHylands/QolsysController@cdef14588dbdd37c9f5061ad97376e4829c2236d -
Branch / Tag:
refs/tags/v0.2.9 - Owner: https://github.com/EHylands
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@cdef14588dbdd37c9f5061ad97376e4829c2236d -
Trigger Event:
release
-
Statement type: