2023-11-24 02:36:31 +02:00
|
|
|
extends Node
|
2024-03-17 01:14:31 +02:00
|
|
|
## Manages the connection to the home automation system and provides a unified interface to the different home automation systems.
|
2023-11-24 02:36:31 +02:00
|
|
|
|
2024-03-12 15:51:09 +02:00
|
|
|
const Hass = preload ("res://lib/home_apis/hass/hass.gd")
|
|
|
|
const HassWebSocket = preload ("res://lib/home_apis/hass_ws/hass.gd")
|
2023-11-24 02:36:31 +02:00
|
|
|
|
|
|
|
const apis = {
|
|
|
|
"hass": Hass,
|
|
|
|
"hass_ws": HassWebSocket
|
|
|
|
}
|
|
|
|
|
|
|
|
const methods = [
|
|
|
|
"get_devices",
|
|
|
|
"get_device",
|
|
|
|
"get_state",
|
|
|
|
"set_state",
|
|
|
|
"watch_state"
|
|
|
|
]
|
|
|
|
|
2024-03-17 01:14:31 +02:00
|
|
|
## Emitted when the connection to the home automation system is established
|
2023-11-24 02:36:31 +02:00
|
|
|
signal on_connect()
|
2024-03-17 01:14:31 +02:00
|
|
|
|
|
|
|
## Emitted when the connection to the home automation system is lost
|
2023-11-24 02:36:31 +02:00
|
|
|
signal on_disconnect()
|
2024-03-17 01:14:31 +02:00
|
|
|
|
|
|
|
## The current home automation system adapter
|
2023-11-24 02:36:31 +02:00
|
|
|
var api: Node
|
|
|
|
|
|
|
|
func _ready():
|
|
|
|
print("HomeApi ready")
|
|
|
|
|
2024-01-25 17:29:33 +02:00
|
|
|
var success = Store.settings.load_local()
|
2023-11-24 02:36:31 +02:00
|
|
|
|
2024-01-25 17:29:33 +02:00
|
|
|
if success:
|
2024-01-27 16:13:43 +02:00
|
|
|
start_adapter(Store.settings.type.to_lower(), Store.settings.url, Store.settings.token)
|
2023-11-24 02:36:31 +02:00
|
|
|
|
2024-03-17 01:14:31 +02:00
|
|
|
## Starts the adapter for the given type and url
|
2023-11-24 02:36:31 +02:00
|
|
|
func start_adapter(type: String, url: String, token: String):
|
|
|
|
print("Starting adapter: %s" % type)
|
|
|
|
if api != null:
|
|
|
|
api.on_connect.disconnect(_on_connect)
|
|
|
|
api.on_disconnect.disconnect(_on_disconnect)
|
|
|
|
remove_child(api)
|
|
|
|
api.queue_free()
|
|
|
|
api = null
|
|
|
|
|
|
|
|
api = apis[type].new(url, token)
|
|
|
|
add_child(api)
|
|
|
|
|
|
|
|
api.on_connect.connect(func():
|
2024-01-25 17:29:33 +02:00
|
|
|
Store.house.load_local()
|
2023-11-24 02:36:31 +02:00
|
|
|
on_connect.emit()
|
|
|
|
)
|
|
|
|
|
|
|
|
api.on_disconnect.connect(func():
|
|
|
|
on_disconnect.emit()
|
|
|
|
)
|
|
|
|
|
|
|
|
for method in methods:
|
|
|
|
assert(api.has_method(method), "%s Api does not implement method: %s" % [type, method])
|
|
|
|
|
|
|
|
func _on_connect():
|
|
|
|
on_connect.emit()
|
|
|
|
|
|
|
|
func _on_disconnect():
|
|
|
|
on_disconnect.emit()
|
|
|
|
|
2024-03-17 01:14:31 +02:00
|
|
|
## Returns true if the adapter is connected to the home automation system
|
2023-11-24 02:36:31 +02:00
|
|
|
func has_connected():
|
|
|
|
if api == null:
|
|
|
|
return false
|
|
|
|
return api.has_connected()
|
|
|
|
|
|
|
|
## Get a list of all devices
|
|
|
|
func get_devices():
|
|
|
|
assert(has_connected(), "Not connected")
|
|
|
|
return await api.get_devices()
|
|
|
|
|
|
|
|
## Get a single device by id
|
|
|
|
func get_device(id: String):
|
|
|
|
assert(has_connected(), "Not connected")
|
|
|
|
return await api.get_device(id)
|
|
|
|
|
|
|
|
## Returns the current state of an entity
|
|
|
|
func get_state(entity: String):
|
|
|
|
assert(has_connected(), "Not connected")
|
|
|
|
return await api.get_state(entity)
|
|
|
|
|
|
|
|
## Updates the state of the entity and returns the resulting state
|
2024-03-12 15:51:09 +02:00
|
|
|
func set_state(entity: String, state: Variant, attributes: Dictionary={}):
|
2023-11-24 02:36:31 +02:00
|
|
|
assert(has_connected(), "Not connected")
|
|
|
|
return await api.set_state(entity, state, attributes)
|
|
|
|
|
|
|
|
## Watches the state and each time it changes, calls the callback with the changed state, returns a function to stop watching the state
|
|
|
|
func watch_state(entity: String, callback: Callable):
|
|
|
|
assert(has_connected(), "Not connected")
|
|
|
|
return api.watch_state(entity, callback)
|
2023-12-09 19:39:38 +02:00
|
|
|
|
|
|
|
func _notification(what):
|
2024-03-12 15:51:09 +02:00
|
|
|
if what == NOTIFICATION_WM_CLOSE_REQUEST||what == NOTIFICATION_WM_GO_BACK_REQUEST:
|
2024-01-25 17:29:33 +02:00
|
|
|
# Store.house.save_local()
|
2024-01-27 16:13:43 +02:00
|
|
|
pass
|