Pass server name to zeroconf when known (#665)

This commit is contained in:
J. Nick Koston 2023-11-23 14:25:05 +01:00 committed by GitHub
parent e1447dd249
commit 00a6ce9f6a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -54,6 +54,7 @@ async def _async_zeroconf_get_service_info(
zeroconf_manager: ZeroconfManager, zeroconf_manager: ZeroconfManager,
service_type: str, service_type: str,
service_name: str, service_name: str,
server: str,
timeout: float, timeout: float,
) -> AsyncServiceInfo | None: ) -> AsyncServiceInfo | None:
# Use or create zeroconf instance, ensure it's an AsyncZeroconf # Use or create zeroconf instance, ensure it's an AsyncZeroconf
@ -65,7 +66,7 @@ async def _async_zeroconf_get_service_info(
"host network mode?" "host network mode?"
) from exc ) from exc
try: try:
info = AsyncServiceInfo(service_type, service_name) info = AsyncServiceInfo(service_type, service_name, server=server)
if await info.async_request(zc, int(timeout * 1000)): if await info.async_request(zc, int(timeout * 1000)):
return info return info
except Exception as exc: except Exception as exc:
@ -85,10 +86,15 @@ async def _async_resolve_host_zeroconf(
zeroconf_manager: ZeroconfManager | None = None, zeroconf_manager: ZeroconfManager | None = None,
) -> list[AddrInfo]: ) -> list[AddrInfo]:
service_name = f"{host}.{SERVICE_TYPE}" service_name = f"{host}.{SERVICE_TYPE}"
server = f"{host}.local."
_LOGGER.debug("Resolving host %s via mDNS", service_name) _LOGGER.debug("Resolving host %s via mDNS", service_name)
info = await _async_zeroconf_get_service_info( info = await _async_zeroconf_get_service_info(
zeroconf_manager or ZeroconfManager(), SERVICE_TYPE, service_name, timeout zeroconf_manager or ZeroconfManager(),
SERVICE_TYPE,
service_name,
server,
timeout,
) )
if info is None: if info is None: