Homex
View SourceThis library aims to bring Elixir (and especially Nerves) closer to Home Assistant. This is a work in progress based on the initial idea.
Example
There is a Livebook example example.livemd to get you started! There is also an example repository using Nerves at https://github.com/kevinschweikert/Homex-Nerves-Example
Installation
If available in Hex, the package can be installed
by adding homex to your list of dependencies in mix.exs:
def deps do
[
{:homex, "~> 0.1.0"},
# If you want to use the MQTT library without QUIC support add
# {:quicer, "~> 0.2.15", compile: false, app: false, runtime: false, override: true},
]
endUsage
Supported entity types:
- Sensor
- Switch
- Light
- Camera
Define a module for the type of entity you want to use
defmodule MySwitch do
use Homex.Entity.Switch, name: "my-switch"
def handle_on(entity) do
IO.puts("Switch turned on")
entity
end
def handle_off(entity) do
IO.puts("Switch turned off")
entity
end
endConfigure broker and entities. See Homex.Config module docs for options.
Entities can also be added/removed at runtime with Homex.add_entity/1 or Homex.remove_entity/1.
import Config
config :homex,
broker: [host: "localhost", port: 1883, username: "admin", password: "admin"],
entities: [MySwitch]Add homex to you supervision tree
defmodule MyApp.Application do
def start(_type, _args) do
children =
[
...,
Homex,
...
]
opts = [strategy: :one_for_one, name: MyApp.Supervisor]
Supervisor.start_link(children, opts)
end
endContribution
PRs and Feedback are very welcome!
Acknowledgements and Inspiration
- ex_homeassistant by @Reimerei
- hap by @mtrudel