Skip to main content

Async Python library to interface with iAlarm-MK alarm panels locally

Project description

🚨 Open iAlarm-MK Local API

Asynchronous Python library for iAlarm-MK alarm panels via the local Meian protocol

Python Version License Version Tests

FeaturesInstallationQuick StartDocumentationExamplesTesting


Features

Performance

  • Built with asyncio for non-blocking operations
  • Efficient TCP communication over the Meian binary protocol
  • TCP keep-alive to prevent idle connection drops

Reliability

  • Framed two-phase read: large MK7 responses (>1024 bytes) always received in full
  • Graceful error propagation with full detail preserved
  • Auto-close socket on connection failure
  • Auto-reconnect: each command retries once on connection drop
  • Concurrent-safe: internal asyncio.Lock serializes all commands (Home Assistant coordinator safe)
  • Application-level keepalive: polls status every 30 s to prevent panel idle timeouts

Developer Friendly

  • Type-safe dataclasses: AlarmStatusModel, ZoneModel, NetworkInfoModel
  • Async context manager support
  • Comprehensive logging at every step

Full Control

  • Arm Away, Arm Stay, Arm Partial, Disarm, Cancel Alarm
  • Read all zones with status (open, bypassed, low battery, signal loss)
  • Read network info (name, MAC, IP)

Installation

git clone https://github.com/VoidElle/open-ialarm-mk-local-api
cd open-ialarm-mk-local-api
pip install -e .

Quick Start

import asyncio
from open_ialarm_mk_local_api import IAlarmMkClient

async def main():
    async with IAlarmMkClient("192.168.1.100", 8000, "admin", "secret") as client:
        status = await client.get_status()
        print(f"Status: {status.status.name}")

        zones = await client.get_zones()
        for zone in zones:
            print(f"  [{zone.index:3d}] {zone.name} - {'OPEN' if zone.is_open else 'ok'}")

asyncio.run(main())

Panel Port

Model Default TCP port
iAlarm MK7 8000
iAlarm MK2 18034

Documentation


Configuration

Constructor Parameters: IAlarmMkClient

Parameter Type Default Description
host str required IP address of the panel
port int required TCP port (8000 for MK7, 18034 for MK2)
username str required Login username
password str required Login password
timeout float 10.0 Socket timeout in seconds
keepalive_interval int | None 30 Seconds between keepalive polls; None to disable

Connection Management

Connect / Disconnect

await client.connect()
await client.disconnect()

Context Manager (recommended)

async with IAlarmMkClient("192.168.1.100", 8000, "admin", "pass") as client:
    status = await client.get_status()

Alarm Control

await client.arm_away()      # Arm all zones
await client.arm_stay()      # Perimeter zones only
await client.arm_partial()   # Partial arm
await client.disarm()        # Disarm
await client.cancel_alarm()  # Cancel active alarm

Data Models

AlarmStatusModel

Field Type Description
status AlarmStatusEnum Current panel status

AlarmStatusEnum

Value Name Description
0 ARMED_AWAY Armed, all zones
1 DISARMED Disarmed
2 ARMED_STAY Armed, stay mode
3 CANCEL Alarm cancelled
4 TRIGGERED Alarm triggered
5 ALARM_ARMING Arming in progress
6 UNAVAILABLE Status unknown
8 ARMED_PARTIAL Armed, partial

ZoneModel

Field / Property Type Description
index int Zone index
name str Zone name
zone_type int Zone type code
status ZoneStatusEnum Raw status bitmask
is_open bool Zone is faulted / open
is_bypassed bool Zone is bypassed
low_battery bool Low battery detected
signal_loss bool Wireless signal lost

NetworkInfoModel

Field Type Description
name str Panel device name
mac str MAC address
ip str IP address

Error Handling

Exception When raised
IAlarmMkConnectionError TCP failure, timeout, or unexpected error during login
IAlarmMkLoginError Panel rejected credentials
IAlarmMkAlarmError Panel returned a non-zero error code for a command
from open_ialarm_mk_local_api import IAlarmMkConnectionError, IAlarmMkLoginError

try:
    async with IAlarmMkClient("192.168.1.100", 8000, "admin", "pass") as client:
        await client.arm_away()
except IAlarmMkLoginError:
    print("Wrong credentials")
except IAlarmMkConnectionError as e:
    print(f"Connection failed: {e}")

Examples

Run any example directly from the repo root (no install needed):

python3 examples/get_status.py --host 192.168.1.100 --user admin --password password
python3 examples/arm_away.py   --host 192.168.1.100 --user admin --password password arm-partial
python3 examples/subscribe_events.py --host 192.168.1.100 --user admin

Integration test against a real panel

python3 examples/integration_test.py --host 192.168.1.100 --user admin --password password
# skip arm/disarm on a live production panel:
python3 examples/integration_test.py --host 192.168.1.100 --user admin --password password --skip-arm

Testing

python -m pytest tests/

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

open_ialarm_mk_local_api-1.0.1.tar.gz (27.5 kB view details)

Uploaded Source

Built Distribution

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

open_ialarm_mk_local_api-1.0.1-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file open_ialarm_mk_local_api-1.0.1.tar.gz.

File metadata

  • Download URL: open_ialarm_mk_local_api-1.0.1.tar.gz
  • Upload date:
  • Size: 27.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for open_ialarm_mk_local_api-1.0.1.tar.gz
Algorithm Hash digest
SHA256 5457a5438869e4d4202ec5e554981ba96c5f4260f1068b92210dbfd7ed88b2b4
MD5 cd47f0f8a1c1a100ed6b5310da6fc359
BLAKE2b-256 a27780553329f02552c76cd3c9acf432ada6742d005d54e68f16642378be6507

See more details on using hashes here.

Provenance

The following attestation bundles were made for open_ialarm_mk_local_api-1.0.1.tar.gz:

Publisher: publish.yml on VoidElle/open-ialarm-mk-local-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file open_ialarm_mk_local_api-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for open_ialarm_mk_local_api-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d730485abe850b632b5fabfa73fa0c2a585ee5e0f6ab6925381a91a64fd9ef3f
MD5 4b7ad8692a6a9a581811539ff43cb05d
BLAKE2b-256 d62cf1d94c3d5c73e6ed730dbd8b0c9c3d7634131db6ed4e3b70c17584cf73c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for open_ialarm_mk_local_api-1.0.1-py3-none-any.whl:

Publisher: publish.yml on VoidElle/open-ialarm-mk-local-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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