Soundtouch-Autodiscovery hinzugefügt
This commit is contained in:
30
soundtouch_autodiscover.py
Normal file
30
soundtouch_autodiscover.py
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
from libsoundtouch import soundtouch_device, discover_devices
|
||||||
|
from libsoundtouch.utils import Source, Type
|
||||||
|
from prettytable import PrettyTable
|
||||||
|
import re
|
||||||
|
|
||||||
|
x = PrettyTable()
|
||||||
|
x.field_names = ["DEVICE NAME", "DEVICE ID", "DEVICE IP", "DEVICE MAC", "DEVICE STATUS", "ZONE STATUS", "DEVICE TYPE"]
|
||||||
|
x.align["DEVICE NAME"] = "l"
|
||||||
|
x.align["DEVICE ID"] = "l"
|
||||||
|
x.align["DEVICE IP"] = "l"
|
||||||
|
x.align["DEVICE MAC"] = "l"
|
||||||
|
x.align["DEVICE STATUS"] = "l"
|
||||||
|
x.align["ZONE STATUS"] = "l"
|
||||||
|
x.align["DEVICE TYPE"] = "l"
|
||||||
|
|
||||||
|
devices = discover_devices(timeout=2) # Default timeout is 5 seconds
|
||||||
|
|
||||||
|
for device in devices:
|
||||||
|
status = device.status()
|
||||||
|
zone_status = device.zone_status()
|
||||||
|
mac = re.sub(r'(.{2})(?!$)', r'\1:', device.config.mac_address)
|
||||||
|
if zone_status:
|
||||||
|
if zone_status.is_master:
|
||||||
|
zone_status = 'Master'
|
||||||
|
else:
|
||||||
|
zone_status = 'Slave'
|
||||||
|
|
||||||
|
x.add_row([device.config.name, device.config.device_id, device.config.device_ip, mac , status.source, zone_status, device.config.type])
|
||||||
|
|
||||||
|
print(x)
|
||||||
Reference in New Issue
Block a user