Skip to content

Commit

Permalink
On Darwin, wait until GetAddrInfo returns all the results before call…
Browse files Browse the repository at this point in the history
…ing the resolve callback.
  • Loading branch information
bzbarsky-apple committed Feb 16, 2022
1 parent 8daad89 commit 75be11e
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 2 deletions.
18 changes: 16 additions & 2 deletions src/platform/Darwin/DnssdImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -409,12 +409,23 @@ static void OnGetAddrInfo(DNSServiceRef sdRef, DNSServiceFlags flags, uint32_t i
service.mTextEntrySize = sdCtx->textEntries.empty() ? 0 : sdCtx->textEntries.size();
chip::Inet::IPAddress ip;
CHIP_ERROR status = chip::Inet::IPAddress::GetIPAddressFromSockAddr(*address, ip);
service.mAddress.SetValue(ip);
if (status == CHIP_NO_ERROR)
{
service.mAddress.SetValue(ip);
}
Platform::CopyString(service.mName, sdCtx->name);
Platform::CopyString(service.mHostName, hostname);
service.mInterface = Inet::InterfaceId(sdCtx->interfaceId);
sdCtx->services.push_back(service);

if (flags & kDNSServiceFlagsMoreComing)
{
// Wait for that.
return;
}

sdCtx->callback(sdCtx->context, Span<DnssdService>(&service, 1), status);
// TODO: Does it really make sense to pass in the status from our last "get the IP address" operation?
sdCtx->callback(sdCtx->context, Span<DnssdService>(sdCtx->services.data(), sdCtx->services.size()), status);
MdnsContexts::GetInstance().Remove(sdCtx);
}

Expand Down Expand Up @@ -512,6 +523,9 @@ static void OnResolve(DNSServiceRef sdRef, DNSServiceFlags flags, uint32_t inter

GetAddrInfo(sdCtx->context, sdCtx->callback, interfaceId, sdCtx->addressType, sdCtx->name, hostname, ntohs(port), txtLen,
txtRecord);

// TODO: If flags & kDNSServiceFlagsMoreComing should we keep waiting to see
// what else we resolve instead of calling Remove() here?
MdnsContexts::GetInstance().Remove(sdCtx);
}

Expand Down
1 change: 1 addition & 0 deletions src/platform/Darwin/DnssdImpl.h
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,7 @@ struct ResolveContext : public GenericContext
struct GetAddrInfoContext : public GenericContext
{
DnssdResolveCallback callback;
std::vector<DnssdService> services;
std::vector<TextEntry> textEntries;
char name[Common::kInstanceNameMaxLength + 1];
uint32_t interfaceId;
Expand Down

0 comments on commit 75be11e

Please sign in to comment.