Skip to content

Latest commit

 

History

History
147 lines (109 loc) · 4.17 KB

README.md

File metadata and controls

147 lines (109 loc) · 4.17 KB

Home Assistant add-on: Futurehome FIMP to MQTT

About

This Futurehome FIMP to MQTT add-on allows you to integrate the Futurehome Smarthub with Home Assistant by using the local MQTT broker inside the hub.

While it is possible to configure Home Assistant the FIMP protocol directly is a lot of work, and auto discovery is not possible.

This addon configure devices and their capabilities from Future Home in Home Assistant using MQTT Discovery.

Read more about the FIMP protocol.

Supported Futurehome devices

  • Appliances (switches in HA)
    • Wall plugs like Fibaro Wall plug is supported
  • Lights (lights in HA)
    • Dimmers - On/Off and brightness. Tested with Fibaro dimmer 2
    • Switches - On/Off. Tested with Fibaro wall plug
  • Sensors
    • Battery
    • Illuminance
    • Presence
    • Temperature
    • Accumulated energy usage (kWh) (meter_elec) for devices supporting this
  • Modus (home, away, sleep and vacation)
    • Set in entity sensor.fh_mode (read only)

Untested in new version (0.1 vs 0.2)

These things are probably no longer working

  • Scene control. Exposed as sensor. Tested with Fibaro button, and Namron 4 channel (K8)

Configuration and installation

1. Home Assistant configuration

Home Assistant must use the MQTT broker provided by the Futurehome Smart hub. It's recommended to configure MQTT via GUI, and not via .yaml

# MQTT
mqtt:
  # Futurehome smart hub
  broker: *hub ip*
  username: *username*
  password: *password*
  port: 1884
  discovery: true
  discovery_prefix: homeassistant

2. Install add-on

  1. Add this repo as an add-on repository
  2. Install the addon 'Futurehome FIMP to MQTT'
  3. Configure the addon with the same parameters as before
  4. Start it. Supported devices should appear in the Home Assistant UI

Development

As this addon is not dependent on Home Assistant it's easiest to develop new features locally, or by using the Dev Container capabilities in VS Code which provides a full Home Assistant setup.

Using virtual env

Git clone and installation

git clone https://github.com/runelangseid/hassio-futurehome2mqtt
cd hassio-futurehome2mqtt/futurehome2mqtt
virtualenv venv  # You might need to specify python 3 somehow: virtualenv -p python3.7 venv
source venv/bin/activate
pip install --upgrade pip
pip install -r requirements.txt

Configuration

  1. Setup configuration

    cp env-dist .env
    
  2. Edit .env and fill in hostnames and credentials

  3. Run source .env && python run.py serve

Alternative FIMP integrations

Below are examples on how to add Wall plugs and sensors manually to Home Assistant using MQTT without the use of this addon.

Wall plug (Fibaro)

Replace '34' with the address for the device in Futurehome.

mqtt:
  #
  # Kontor
  #
  # Wall plug
  switch: 
    - name: "Wall plug (kontor)"
      state_topic:   "pt:j1/mt:evt/rt:dev/rn:zw/ad:1/sv:out_bin_switch/ad:34_0"
      command_topic: "pt:j1/mt:cmd/rt:dev/rn:zw/ad:1/sv:out_bin_switch/ad:34_0"
      value_template: '{{ value_json.val }}'
      payload_on:  '{"props":{},"serv":"out_bin_switch","tags":[],"type":"cmd.binary.set","val":true,"val_t":"bool"}'
      payload_off: '{"props":{},"serv":"out_bin_switch","tags":[],"type":"cmd.binary.set","val":false,"val_t":"bool"}'
      state_on: true
      state_off: false

Multi Sensor (Fibaro)

Replace '37' with the address for the device in Futurehome.

mqtt:
  # Fibaro Eye
  sensor:
    - name: "Batteri Kontor"
      state_topic: "pt:j1/mt:evt/rt:dev/rn:zw/ad:1/sv:battery/ad:37_0"
      unit_of_measurement: '%'
      value_template: "{{ value_json.val }}"
  
    - name: "Bevegelse Kontor"
      state_topic: "pt:j1/mt:evt/rt:dev/rn:zw/ad:1/sv:sensor_presence/ad:37_0"
      value_template: "{{ value_json.val }}"
  
    - name: "Temperatur Kontor"
      state_topic: "pt:j1/mt:evt/rt:dev/rn:zw/ad:1/sv:sensor_temp/ad:37_0"
      unit_of_measurement: '°C'
      value_template: "{{ value_json.val }}"
  
    - name: "Lysstyrke Kontor"
      state_topic: "pt:j1/mt:evt/rt:dev/rn:zw/ad:1/sv:sensor_lumin/ad:37_0"
      unit_of_measurement: 'Lux'
      value_template: "{{ value_json.val }}"