Skip to content

Commit

Permalink
Fix android icd checkin message
Browse files Browse the repository at this point in the history
  • Loading branch information
joonhaengHeo committed May 23, 2024
1 parent 6bd80b0 commit bc1e00c
Show file tree
Hide file tree
Showing 8 changed files with 78 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -238,6 +238,16 @@ class CHIPToolActivity :
}
}

override fun onResume() {
super.onResume()
ChipClient.startDnssd()
}

override fun onPause() {
ChipClient.stopDnssd()
super.onPause()
}

companion object {
private const val TAG = "CHIPToolActivity"
private const val ADDRESS_COMMISSIONING_FRAGMENT_TAG = "address_commissioning_fragment"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,18 @@ object ChipClient {
icdCheckInCallback = callback
}

fun startDnssd() {
if (this::chipDeviceController.isInitialized) {
chipDeviceController.startDnssd()
}
}

fun stopDnssd() {
if (this::chipDeviceController.isInitialized) {
chipDeviceController.stopDnssd()
}
}

/**
* Wrapper around [ChipDeviceController.getConnectedDevicePointer] to return the value directly.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,10 @@ class AddressUpdateFragment : ICDCheckInCallback, Fragment() {
val runnable =
object : Runnable {
override fun run() {
if (!isAdded) {
Log.d(TAG, "Fragment is not attached")
return
}
if (icdTotalRemainStayActiveTimeMs >= ICD_PROGRESS_STEP) {
icdDeviceRemainStayActiveTimeMs -= ICD_PROGRESS_STEP
icdTotalRemainStayActiveTimeMs -= ICD_PROGRESS_STEP
Expand Down
12 changes: 12 additions & 0 deletions src/controller/java/AndroidDeviceControllerWrapper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@

#include <string.h>

#include <app/server/Dnssd.h>

#include <lib/support/CodeUtils.h>
#include <lib/support/JniReferences.h>
#include <lib/support/JniTypeWrappers.h>
Expand Down Expand Up @@ -1085,3 +1087,13 @@ CHIP_ERROR AndroidDeviceControllerWrapper::SyncDeleteKeyValue(const char * key)
ChipLogProgress(chipTool, "KVS: Deleting key %s", StringOrNullMarker(key));
return chip::DeviceLayer::PersistedStorage::KeyValueStoreMgr().Delete(key);
}

void AndroidDeviceControllerWrapper::StartDnssd() {
chip::app::DnssdServer::Instance().StartServer();
}

void AndroidDeviceControllerWrapper::StopDnssd() {
chip::app::DnssdServer::Instance().StopServer();
FabricTable * fabricTable = DeviceControllerFactory::GetInstance().GetSystemState()->Fabrics();
chip::app::DnssdServer::Instance().SetFabricTable(fabricTable);
}
4 changes: 4 additions & 0 deletions src/controller/java/AndroidDeviceControllerWrapper.h
Original file line number Diff line number Diff line change
Expand Up @@ -214,6 +214,10 @@ class AndroidDeviceControllerWrapper : public chip::Controller::DevicePairingDel

CHIP_ERROR SetICDCheckInDelegate(jobject checkInDelegate);

void StartDnssd();

void StopDnssd();

private:
using ChipDeviceControllerPtr = std::unique_ptr<chip::Controller::DeviceCommissioner>;

Expand Down
14 changes: 14 additions & 0 deletions src/controller/java/CHIPDeviceController-JNI.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2154,6 +2154,20 @@ JNI_METHOD(jbyteArray, validateAndExtractCSR)(JNIEnv * env, jclass clazz, jbyteA
return javaCsr;
}

JNI_METHOD(void, startDnssd)(JNIEnv * env, jobject self, jlong devicePtr)
{
ChipLogProgress(Controller, "startDnssd() called");
chip::DeviceLayer::StackLock lock;

}

JNI_METHOD(void, stopDnssd)(JNIEnv * env, jobject self, jlong devicePtr)
{
ChipLogProgress(Controller, "stopDnssd() called");
chip::DeviceLayer::StackLock lock;

}

void * IOThreadMain(void * arg)
{
JNIEnv * env;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -803,6 +803,14 @@ public byte[] getAttestationChallenge(long devicePtr) {
return getAttestationChallenge(deviceControllerPtr, devicePtr);
}

public void startDnssd() {
startDnssd(deviceControllerPtr);
}

public void stopDnssd() {
stopDnssd(deviceControllerPtr);
}

/**
* @brief Auto-Resubscribe to the given attribute path with keepSubscriptions and isFabricFiltered
* @param SubscriptionEstablishedCallback Callback when a subscribe response has been received and
Expand Down Expand Up @@ -1587,6 +1595,10 @@ private native void updateCommissioningICDRegistrationInfo(

private native void shutdownCommissioning(long deviceControllerPtr);

private native void startDnssd(long deviceControllerPtr);

private native void stopDnssd(long deviceControllerPtr);

static {
System.loadLibrary("CHIPController");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ public class NsdManagerServiceResolver implements ServiceResolver {
private static final long RESOLVE_SERVICE_TIMEOUT = 30000;
private final NsdManager nsdManager;
private MulticastLock multicastLock;
private MulticastLock publishMulticastLock;
private List<NsdManager.RegistrationListener> registrationListeners = new ArrayList<>();
private final CopyOnWriteArrayList<String> mMFServiceName = new CopyOnWriteArrayList<>();
@Nullable private final NsdManagerResolverAvailState nsdManagerResolverAvailState;
Expand All @@ -60,6 +61,12 @@ public NsdManagerServiceResolver(
((WifiManager) context.getSystemService(Context.WIFI_SERVICE))
.createMulticastLock("chipMulticastLock");
this.multicastLock.setReferenceCounted(true);

this.publishMulticastLock =
((WifiManager) context.getSystemService(Context.WIFI_SERVICE))
.createMulticastLock("chipPublishMulticastLock");
this.publishMulticastLock.setReferenceCounted(true);

this.nsdManagerResolverAvailState = nsdManagerResolverAvailState;
this.timeout = timeout;
}
Expand Down Expand Up @@ -204,7 +211,7 @@ public void onServiceUnregistered(NsdServiceInfo serviceInfo) {
}
};
if (registrationListeners.size() == 0) {
multicastLock.acquire();
publishMulticastLock.acquire();
}
registrationListeners.add(registrationListener);
mMFServiceName.add(serviceName);
Expand All @@ -216,8 +223,8 @@ public void onServiceUnregistered(NsdServiceInfo serviceInfo) {
@Override
public void removeServices() {
Log.d(TAG, "removeServices: ");
if (registrationListeners.size() > 0) {
multicastLock.release();
if (registrationListeners.size() > 0 && publishMulticastLock.isHeld()) {
publishMulticastLock.release();
}
for (NsdManager.RegistrationListener l : registrationListeners) {
Log.i(TAG, "Remove " + l);
Expand Down

0 comments on commit bc1e00c

Please sign in to comment.