mirror of
https://github.com/esphome/aioesphomeapi.git
synced 2025-01-21 21:31:36 +01:00
Add discover cli tool (#732)
This commit is contained in:
parent
6e08933a75
commit
f230825651
@ -5,6 +5,7 @@ omit =
|
||||
aioesphomeapi/api_options_pb2.py
|
||||
aioesphomeapi/api_pb2.py
|
||||
aioesphomeapi/log_reader.py
|
||||
aioesphomeapi/discover.py
|
||||
bench/*.py
|
||||
|
||||
[report]
|
||||
|
@ -135,6 +135,12 @@ A cli tool is also available for watching logs:
|
||||
|
||||
aioesphomeapi-logs --help
|
||||
|
||||
A cli tool is also available to discover devices:
|
||||
|
||||
.. code:: bash
|
||||
|
||||
aioesphomeapi-discover
|
||||
|
||||
License
|
||||
-------
|
||||
|
||||
|
80
aioesphomeapi/discover.py
Normal file
80
aioesphomeapi/discover.py
Normal file
@ -0,0 +1,80 @@
|
||||
from __future__ import annotations
|
||||
|
||||
# Helper script and aioesphomeapi to discover api devices
|
||||
import asyncio
|
||||
import logging
|
||||
import sys
|
||||
|
||||
from zeroconf import IPVersion, ServiceStateChange, Zeroconf
|
||||
from zeroconf.asyncio import AsyncServiceBrowser, AsyncServiceInfo, AsyncZeroconf
|
||||
|
||||
FORMAT = "{: <7}|{: <32}|{: <15}|{: <12}|{: <16}|{: <10}|{: <32}"
|
||||
COLUMN_NAMES = ("Status", "Name", "Address", "MAC", "Version", "Platform", "Board")
|
||||
|
||||
|
||||
def decode_bytes_or_none(data: str | bytes | None) -> str | None:
|
||||
"""Decode bytes or return None."""
|
||||
if data is None:
|
||||
return None
|
||||
if isinstance(data, bytes):
|
||||
return data.decode()
|
||||
return data
|
||||
|
||||
|
||||
def async_service_update(
|
||||
zeroconf: Zeroconf,
|
||||
service_type: str,
|
||||
name: str,
|
||||
state_change: ServiceStateChange,
|
||||
) -> None:
|
||||
"""Service state changed."""
|
||||
short_name = name.partition(".")[0]
|
||||
if state_change is ServiceStateChange.Removed:
|
||||
state = "OFFLINE"
|
||||
else:
|
||||
state = "ONLINE"
|
||||
info = AsyncServiceInfo(service_type, name)
|
||||
info.load_from_cache(zeroconf)
|
||||
properties = info.properties
|
||||
mac = decode_bytes_or_none(properties.get(b"mac"))
|
||||
version = decode_bytes_or_none(properties.get(b"version"))
|
||||
platform = decode_bytes_or_none(properties.get(b"platform"))
|
||||
board = decode_bytes_or_none(properties.get(b"board"))
|
||||
address = None
|
||||
if addresses := info.ip_addresses_by_version(IPVersion.V4Only):
|
||||
address = str(addresses[0])
|
||||
|
||||
print(FORMAT.format(state, short_name, address, mac, version, platform, board))
|
||||
|
||||
|
||||
async def main() -> None:
|
||||
logging.basicConfig(
|
||||
format="%(asctime)s.%(msecs)03d %(levelname)-8s %(message)s",
|
||||
level=logging.INFO,
|
||||
datefmt="%Y-%m-%d %H:%M:%S",
|
||||
)
|
||||
aiozc = AsyncZeroconf()
|
||||
browser = AsyncServiceBrowser(
|
||||
aiozc.zeroconf, "_esphomelib._tcp.local.", handlers=[async_service_update]
|
||||
)
|
||||
print(FORMAT.format(*COLUMN_NAMES))
|
||||
print("-" * 120)
|
||||
|
||||
try:
|
||||
await asyncio.Event().wait()
|
||||
finally:
|
||||
await browser.async_cancel()
|
||||
await aiozc.async_close()
|
||||
|
||||
|
||||
def cli_entry_point() -> None:
|
||||
"""Run the CLI."""
|
||||
try:
|
||||
asyncio.run(main())
|
||||
except KeyboardInterrupt:
|
||||
pass
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
cli_entry_point()
|
||||
sys.exit(0)
|
3
setup.py
3
setup.py
@ -61,7 +61,8 @@ setup_kwargs = {
|
||||
"test_suite": "tests",
|
||||
"entry_points": {
|
||||
"console_scripts": [
|
||||
"aioesphomeapi-logs=aioesphomeapi.log_reader:cli_entry_point"
|
||||
"aioesphomeapi-logs=aioesphomeapi.log_reader:cli_entry_point",
|
||||
"aioesphomeapi-discover=aioesphomeapi.discover:cli_entry_point",
|
||||
],
|
||||
},
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user