Skip to main content

Homeassistant PHAL plugin for OpenVoiceOS

Project description

OVOS PHAL Home Assistant Plugin

The PHAL Plugin provides GUI interfaces and API for Home Assistant Instants.

NOTE: this plugin is roadmapped for merging with https://github.com/OpenVoiceOS/ovos-PHAL-plugin-commonIOT for ovos-core release 0.0.9, the UI will become IOT framework agnostic

Demo GIF

HomeAssistant PHAL Demo

Installation

Plugin Support Two Installation Methods:

  1. Install from Github URL

Note: PIP install from URL will not install the .desktop file and icon if installing to a venv or virtual environment, so you need to manually install them to the system or user directory.

Note: PIP install will attempt to install the .desktop file and icon to the system directory, or user directory if the system directory is not writable. If this is not a virtual environemnt.

pip install git+https://github.com/OpenVoiceOS/ovos-PHAL-plugin-homeassistant
  1. Manual Install from Git Clone
git clone https://github.com/OpenVoiceOS/ovos-PHAL-plugin-homeassistant
cd ovos-PHAL-plugin-homeassistant
cp -r res/desktop/ovos-phal-homeassistant.desktop ~/.local/share/applications/
cp -r res/icon/ovos-phal-homeassistant.png ~/.local/share/icons/
pip install .

Configuration (Instance Setup)

Plugin Supports Two Configuration Methods:

  1. Using the GUI

    • Install the plugin
    • Open the application from the homescreen menu
    • Click the "Connect Instance" button
    • Enter the URL of the Home Assistant Instance
    • Enter the Long-Lived Access Token (API KEY)
    • Press the "Confirm" button
  2. Manually Editing the Config File

    • Add the following to the config file:
         "PHAL": {
             "ovos-PHAL-plugin-homeassistant": {
                 "host": "https://someurl.toinstance",
                 "api_key": "api key from the instance"
             }
         }
    

The config also takes some optional properties:

brightness_increment - the amount to increment/decrement the brightness of a light when the brightness up/down commands are sent. The default value is 10 and represents a percentage, e.g. 10%. search_confidence_threshold - the confidence threshold for the search skill to use when searching for devices. The default value is 0.5, or 50%. Must be a value between 0 and 1. assist_only - whether to pull down only entities exposed to Assist. Default True. toggle_automations - whether to allow the plugin to turn automations on and off. Default False.

Sample config:

        "PHAL": {
            "ovos-PHAL-plugin-homeassistant": {
                "host": "https://someurl.toinstance",
                "api_key": "api key from the instance",
                "brightness_increment": 5,
                "search_confidence_threshold": 0.6,
                "toggle_automations": false,
            }
        }

Usage

The plugin provides a GUI interface for Home Assistant Instances. It also provides an API for other plugins or skills to user.

The plugin is in early development, so there are some features that are not yet implemented. It currently supports the following entities:

  • Media Player
  • Light
  • Vacuum
  • Binary Sensor
  • Sensor

BUS API (For Other Plugins / GUIs) - WIP / TODO Documentation

EXPANDING DEVICE / ENTITY SUPPORT - WIP / TODO Documentation


Technical Documentation

Python Controller Class Specification:

Depending on how the controller communicates with the host instance, the minimum required connector initialization properties are:

  • host (type: string): Address to host instance
  • api_key (type: string): Access key for host instance authentication

Python Device Class Specification:

All devices are required to support the below minimal properties for device initialization.

  • controller (type: string): An instance of the controller class that handles all communications with the API the device talks to for example HomeAssistantConnector, All devices will use the controller class for any kind of communication.
  • device_id (type: string): A device id to associate all communications with this device with, for HomeAssistant device_id = entity_id, all device_id start with device_type.device_name.
  • device_icon (type: string): A device icon to associate the device display icon with including type, for example: "mdi:light" for device type light, "mdi:sensor" for device type sensor, "mdi:media_player" for device type media_player
  • device_name (type: string): A human readable device name that can be used for spoken and visual material
  • device_state (type: string): A device can have multiple states depending on which type of device it is, for example a light can have an "on", "off" and "unavailable" states, a media_player can have "playing", "paused", "off", "on" and "unavailable" states. Refer to HomeAssistant entities list for complete list of entity states
  • device_attributes (type: dict): Device attributes provide information of the device such as supported properties and values, they can consist of information such as: "brightness", "rgb_color", "supported_color_mode" in case of lights for example. Refer to HomeAssistant entities list for complete list of entity attributes

QML GUI Device Display Model Specification:

  • id (type: string): Device ID as per the device class specification.
  • name (type: string): Device display name as per the device class specification
  • icon (type: string): Device icon name as per the device class specification
  • state (type: string): Device state as updated or provided by device in the device class specification
  • type (type: string): Device type assigned to the device when the device is registerd, this is not an initialization property and is extracted from the device_id where device_id = "device_type.device_name" generally in HomeAssistant API
  • attributes (type: dict): Device attributes as provided by the device during various state changes and initial state at time of registeration

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

ovos-PHAL-plugin-homeassistant-0.0.4a8.tar.gz (68.1 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file ovos-PHAL-plugin-homeassistant-0.0.4a8.tar.gz.

File metadata

File hashes

Hashes for ovos-PHAL-plugin-homeassistant-0.0.4a8.tar.gz
Algorithm Hash digest
SHA256 22cd91fb671a058ff1e55e644ccf88864bd2160883d6c776d236d800c97b0725
MD5 3195ea4ff9a8ccedf35781c10e4a2e3e
BLAKE2b-256 0acdaca3ce62487970165b3422888c8ad88fbbb9019ea227783949da860d1ac4

See more details on using hashes here.

File details

Details for the file ovos_PHAL_plugin_homeassistant-0.0.4a8-py3-none-any.whl.

File metadata

File hashes

Hashes for ovos_PHAL_plugin_homeassistant-0.0.4a8-py3-none-any.whl
Algorithm Hash digest
SHA256 26d30f7f1b12620cc6c01e7b95200206f507f34389510a8bf2a7e9577f013f22
MD5 4dc6998cc3187006665f2298323a9f23
BLAKE2b-256 d5617007a04b1ce775ffe8bde2eafabda3bb2a6f33dd220e210bb6b031738d19

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