Skip to content

Commit

Permalink
Add Android Checkin
Browse files Browse the repository at this point in the history
  • Loading branch information
joonhaengHeo committed Mar 7, 2024
1 parent b742587 commit bcdf546
Show file tree
Hide file tree
Showing 7 changed files with 36 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ object ChipClient {

if (!this::chipDeviceController.isInitialized) {
chipDeviceController =
ChipDeviceController(ControllerParams.newBuilder().setControllerVendorId(VENDOR_ID).build())
ChipDeviceController(ControllerParams.newBuilder().setControllerVendorId(VENDOR_ID).setEnableServerInteractions(true).build())

// Set delegate for attestation trust store for device attestation verifier.
// It will replace the default attestation trust store.
Expand Down
11 changes: 10 additions & 1 deletion src/controller/java/AndroidDeviceControllerWrapper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ AndroidDeviceControllerWrapper * AndroidDeviceControllerWrapper::AllocateNew(
jobject keypairDelegate, jbyteArray rootCertificate, jbyteArray intermediateCertificate, jbyteArray nodeOperationalCertificate,
jbyteArray ipkEpochKey, uint16_t listenPort, uint16_t controllerVendorId, uint16_t failsafeTimerSeconds,
bool attemptNetworkScanWiFi, bool attemptNetworkScanThread, bool skipCommissioningComplete,
bool skipAttestationCertificateValidation, CHIP_ERROR * errInfoOnFailure)
bool skipAttestationCertificateValidation, bool enableServerInteractions, CHIP_ERROR * errInfoOnFailure)
{
if (errInfoOnFailure == nullptr)
{
Expand Down Expand Up @@ -332,6 +332,9 @@ AndroidDeviceControllerWrapper * AndroidDeviceControllerWrapper::AllocateNew(
setupParams.controllerNOC = nocSpan;
}

initParams.enableServerInteractions = enableServerInteractions;
setupParams.enableServerInteractions = enableServerInteractions;

*errInfoOnFailure = DeviceControllerFactory::GetInstance().Init(initParams);
if (*errInfoOnFailure != CHIP_NO_ERROR)
{
Expand Down Expand Up @@ -374,6 +377,11 @@ AndroidDeviceControllerWrapper * AndroidDeviceControllerWrapper::AllocateNew(

wrapper->getICDClientStorage()->UpdateFabricList(wrapper->Controller()->GetFabricIndex());

auto engine = chip::app::InteractionModelEngine::GetInstance();
*errInfoOnFailure = wrapper->mCheckInDelegate.Init(&wrapper->mICDClientStorage, engine);
*errInfoOnFailure = wrapper->mCheckInHandler.Init(DeviceControllerFactory::GetInstance().GetSystemState()->ExchangeMgr(),
&wrapper->mICDClientStorage, &wrapper->mCheckInDelegate, engine);

memset(ipkBuffer.data(), 0, ipkBuffer.size());

if (*errInfoOnFailure != CHIP_NO_ERROR)
Expand Down Expand Up @@ -749,6 +757,7 @@ void AndroidDeviceControllerWrapper::OnReadCommissioningInfo(const chip::Control

// For ICD
mUserActiveModeTriggerHint = info.icd.userActiveModeTriggerHint;
memset(mUserActiveModeTriggerInstructionBuffer, 0x00, kUserActiveModeTriggerInstructionBufferLen);
CopyCharSpanToMutableCharSpan(info.icd.userActiveModeTriggerInstruction, mUserActiveModeTriggerInstruction);

env->CallVoidMethod(mJavaObjectRef.ObjectRef(), onReadCommissioningInfoMethod, static_cast<jint>(info.basic.vendorId),
Expand Down
6 changes: 5 additions & 1 deletion src/controller/java/AndroidDeviceControllerWrapper.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@

#include <jni.h>

#include <app/icd/client/CheckInHandler.h>
#include <app/icd/client/DefaultCheckInDelegate.h>
#include <app/icd/client/DefaultICDClientStorage.h>
#include <controller/CHIPDeviceController.h>
#include <credentials/GroupDataProviderImpl.h>
Expand Down Expand Up @@ -184,7 +186,7 @@ class AndroidDeviceControllerWrapper : public chip::Controller::DevicePairingDel
jobject keypairDelegate, jbyteArray rootCertificate, jbyteArray intermediateCertificate,
jbyteArray nodeOperationalCertificate, jbyteArray ipkEpochKey, uint16_t listenPort, uint16_t controllerVendorId,
uint16_t failsafeTimerSeconds, bool attemptNetworkScanWiFi, bool attemptNetworkScanThread,
bool skipCommissioningComplete, bool skipAttestationCertificateValidation, CHIP_ERROR * errInfoOnFailure);
bool skipCommissioningComplete, bool skipAttestationCertificateValidation, bool enableServerInteractions, CHIP_ERROR * errInfoOnFailure);

void Shutdown();

Expand Down Expand Up @@ -223,6 +225,8 @@ class AndroidDeviceControllerWrapper : public chip::Controller::DevicePairingDel
chip::Crypto::RawKeySessionKeystore mSessionKeystore;

chip::app::DefaultICDClientStorage mICDClientStorage;
chip::app::DefaultCheckInDelegate mCheckInDelegate;
chip::app::CheckInHandler mCheckInHandler;

JavaVM * mJavaVM = nullptr;
chip::JniGlobalReference mJavaObjectRef;
Expand Down
7 changes: 6 additions & 1 deletion src/controller/java/CHIPDeviceController-JNI.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -350,6 +350,10 @@ JNI_METHOD(jlong, newDeviceController)(JNIEnv * env, jobject self, jobject contr
err = chip::JniReferences::GetInstance().FindMethod(env, controllerParams, "getAdminSubject", "()J", &getAdminSubject);
SuccessOrExit(err);

jmethodID getEnableServerInteractions;
err = chip::JniReferences::GetInstance().FindMethod(env, controllerParams, "getEnableServerInteractions", "()Z", &getEnableServerInteractions);
SuccessOrExit(err);

{
uint64_t fabricId = static_cast<uint64_t>(env->CallLongMethod(controllerParams, getFabricId));
uint16_t listenPort = static_cast<uint16_t>(env->CallIntMethod(controllerParams, getUdpListenPort));
Expand All @@ -370,6 +374,7 @@ JNI_METHOD(jlong, newDeviceController)(JNIEnv * env, jobject self, jobject contr
uint64_t adminSubject = static_cast<uint64_t>(env->CallLongMethod(controllerParams, getAdminSubject));
jobject countryCodeOptional = env->CallObjectMethod(controllerParams, getCountryCode);
jobject regulatoryLocationOptional = env->CallObjectMethod(controllerParams, getRegulatoryLocation);
bool enableServerInteractions = env->CallBooleanMethod(controllerParams, getEnableServerInteractions) == JNI_TRUE;

#ifdef JAVA_MATTER_CONTROLLER_TEST
std::unique_ptr<chip::Controller::ExampleOperationalCredentialsIssuer> opCredsIssuer(
Expand All @@ -383,7 +388,7 @@ JNI_METHOD(jlong, newDeviceController)(JNIEnv * env, jobject self, jobject contr
DeviceLayer::TCPEndPointManager(), DeviceLayer::UDPEndPointManager(), std::move(opCredsIssuer), keypairDelegate,
rootCertificate, intermediateCertificate, operationalCertificate, ipk, listenPort, controllerVendorId,
failsafeTimerSeconds, attemptNetworkScanWiFi, attemptNetworkScanThread, skipCommissioningComplete,
skipAttestationCertificateValidation, &err);
skipAttestationCertificateValidation, enableServerInteractions, &err);
SuccessOrExit(err);

if (caseFailsafeTimerSeconds > 0)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ public final class ControllerParams {
@Nullable private final byte[] operationalCertificate;
@Nullable private final byte[] ipk;
private final long adminSubject;
private final boolean enableServerInteractions;

/** @param udpListenPort the UDP listening port, or 0 to pick any available port. */
private ControllerParams(Builder builder) {
Expand All @@ -43,6 +44,7 @@ private ControllerParams(Builder builder) {
this.operationalCertificate = builder.operationalCertificate;
this.ipk = builder.ipk;
this.adminSubject = builder.adminSubject;
this.enableServerInteractions = builder.enableServerInteractions;
}

public long getFabricId() {
Expand Down Expand Up @@ -114,6 +116,10 @@ public long getAdminSubject() {
return adminSubject;
}

public boolean getEnableServerInteractions() {
return enableServerInteractions;
}

/** Returns parameters with ephemerally generated operational credentials */
public static Builder newBuilder() {
return new Builder();
Expand Down Expand Up @@ -152,6 +158,7 @@ public static class Builder {
@Nullable private byte[] operationalCertificate = null;
@Nullable private byte[] ipk = null;
private long adminSubject = 0;
private boolean enableServerInteractions = false;

private Builder() {}

Expand Down Expand Up @@ -357,6 +364,11 @@ public Builder setAdminSubject(long adminSubject) {
return this;
}

public Builder setEnableServerInteractions(boolean enableServerInteractions) {
this.enableServerInteractions = enableServerInteractions;
return this;
}

public ControllerParams build() {
return new ControllerParams(this);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ constructor(
val udpListenPort: Int = UDP_PORT_AUTO,
val vendorId: Int = VENDOR_ID_TEST,
val countryCode: String? = null,
val enableServerInteractions: Boolean = false,
) {
companion object {
/** Matter assigned vendor ID for Google. */
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -543,6 +543,7 @@ class MatterControllerImpl(params: ControllerParams) : MatterController {
.setUdpListenPort(params.udpListenPort)
.setControllerVendorId(params.vendorId)
.setCountryCode(params.countryCode)
.setEnableServerInteractions(params.enableServerInteractions)

if (config != null) {
val intermediateCertificate = config.certificateData.intermediateCertificate
Expand Down

0 comments on commit bcdf546

Please sign in to comment.