Skip to content

Commit

Permalink
[android] handles unscoped ipv6 link-local address
Browse files Browse the repository at this point in the history
  • Loading branch information
wgtdkp committed Aug 13, 2024
1 parent 639e627 commit 2a89fe5
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -30,12 +30,17 @@

import android.Manifest.permission;
import android.content.Context;
import android.net.ConnectivityManager;
import android.net.Network;
import android.net.nsd.NsdManager;
import android.net.nsd.NsdServiceInfo;
import android.net.wifi.WifiManager;
import android.util.Log;
import androidx.annotation.Nullable;
import androidx.annotation.RequiresPermission;
import com.google.common.net.InetAddresses;
import java.net.Inet6Address;
import java.net.InetAddress;
import java.util.Map;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
Expand All @@ -52,13 +57,14 @@ public class BorderAgentDiscoverer implements NsdManager.DiscoveryListener {
private static final String KEY_NETWORK_NAME = "nn";
private static final String KEY_EXTENDED_PAN_ID = "xp";

private WifiManager.MulticastLock wifiMulticastLock;
private NsdManager nsdManager;
private BorderAgentListener borderAgentListener;
private final WifiManager.MulticastLock wifiMulticastLock;
private final NsdManager nsdManager;
private final ConnectivityManager connManager;
private final BorderAgentListener borderAgentListener;

private ExecutorService executor = Executors.newSingleThreadExecutor();
private BlockingQueue<NsdServiceInfo> unresolvedServices = new ArrayBlockingQueue<>(256);
private AtomicBoolean isResolvingService = new AtomicBoolean(false);
private final BlockingQueue<NsdServiceInfo> unresolvedServices = new ArrayBlockingQueue<>(256);
private final AtomicBoolean isResolvingService = new AtomicBoolean(false);

private boolean isScanning = false;

Expand All @@ -74,7 +80,8 @@ public BorderAgentDiscoverer(Context context, BorderAgentListener borderAgentLis
WifiManager wifi = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);
wifiMulticastLock = wifi.createMulticastLock("multicastLock");

nsdManager = (NsdManager) context.getSystemService(Context.NSD_SERVICE);
nsdManager = context.getSystemService(NsdManager.class);
connManager = context.getSystemService(ConnectivityManager.class);

this.borderAgentListener = borderAgentListener;
}
Expand Down Expand Up @@ -112,7 +119,7 @@ public void onResolveFailed(NsdServiceInfo serviceInfo, int errorCode) {
public void onServiceResolved(NsdServiceInfo serviceInfo) {
BorderAgentInfo borderAgent = getBorderAgentInfo(serviceInfo);
if (borderAgent != null) {
Log.d(TAG, "successfully resolved service: " + serviceInfo.toString());
Log.d(TAG, "successfully resolved service: " + serviceInfo);
Log.d(
TAG,
"successfully resolved service: " + serviceInfo.getHost().getCanonicalHostName());
Expand Down Expand Up @@ -218,6 +225,36 @@ private BorderAgentInfo getBorderAgentInfo(NsdServiceInfo serviceInfo) {
serviceInfo.getPort());
}

/**
* Properly handles the {@link InetAddress} within a discovered {@link NsdServiceInfo}.
*
* For example, adds the scope ID to an IPv6 link-local address to make is usable.
*/
private InetAddress handleNsdServiceAddress(InetAddress address) {
if (address instanceof InetAddress){
return address;
}

Inet6Address address6 = (Inet6Address) address;

// Sets the scope ID for IPv6 link-local address if it's missing. This can
// happen before Android U.
if (address6.isLinkLocalAddress() && address6.getScopeId() == 0) {
// Assume the mDNS service is discovered on the current active default network
Network network = connManager.getActiveNetwork();
if (network == null) {
return address6;
}
String interfaceName = connManager.getLinkProperties(network).getInterfaceName();
if (interfaceName == null) {
return address6;
}
return InetAddresses.forString(address6.getHostAddress() + "%" + interfaceName);
}

return address6;
}

@Nullable
private byte[] getBorderAgentId(NsdServiceInfo serviceInfo) {
Map<String, byte[]> attrs = serviceInfo.getAttributes();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,9 +48,9 @@ public BorderAgentInfo(
@NonNull byte[] extendedPanId,
@NonNull InetAddress host,
@NonNull int port) {
this.id = id.clone();
this.id = id == null ? null : id.clone();
this.networkName = networkName;
this.extendedPanId = extendedPanId.clone();
this.extendedPanId = extendedPanId == null ? null : extendedPanId.clone();
this.host = host;
this.port = port;
}
Expand Down

0 comments on commit 2a89fe5

Please sign in to comment.