AppImpl.cpp 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. *
  3. * Copyright (c) 2023 Project CHIP Authors
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. #include "AppImpl.h"
  18. #include "DeviceApp-JNI.h"
  19. #include <app/server/Server.h>
  20. #include <lib/core/CHIPCore.h>
  21. #include <lib/core/DataModelTypes.h>
  22. #include <platform/CHIPDeviceLayer.h>
  23. using namespace chip;
  24. using namespace chip::DeviceLayer;
  25. void DeviceEventCallback(const ChipDeviceEvent * event, intptr_t arg)
  26. {
  27. ChipLogProgress(DeviceLayer, "DeviceEventCallback : %d", event->Type);
  28. switch (event->Type)
  29. {
  30. case DeviceEventType::kWiFiConnectivityChange:
  31. ChipLogProgress(DeviceLayer, "kWiFiConnectivityChange");
  32. break;
  33. case DeviceEventType::kInternetConnectivityChange:
  34. ChipLogProgress(DeviceLayer, "InternetConnectivityChange");
  35. break;
  36. case DeviceEventType::kServiceConnectivityChange:
  37. ChipLogProgress(DeviceLayer, "ServiceConnectivityChange");
  38. break;
  39. case DeviceEventType::kServiceProvisioningChange:
  40. ChipLogProgress(DeviceLayer, "ServiceProvisioningChange");
  41. break;
  42. case DeviceEventType::kCHIPoBLEConnectionEstablished:
  43. ChipLogProgress(DeviceLayer, "CHIPoBLE connection established");
  44. break;
  45. case DeviceEventType::kCHIPoBLEConnectionClosed:
  46. ChipLogProgress(DeviceLayer, "CHIPoBLE disconnected");
  47. break;
  48. case DeviceEventType::kCHIPoBLEAdvertisingChange:
  49. ChipLogProgress(DeviceLayer, "CHIPoBLEAdvertisingChange");
  50. break;
  51. case DeviceEventType::kInterfaceIpAddressChanged:
  52. ChipLogProgress(DeviceLayer, "InterfaceIpAddressChanged");
  53. break;
  54. case DeviceEventType::kCommissioningComplete:
  55. ChipLogProgress(DeviceLayer, "Commissioning complete");
  56. break;
  57. case DeviceEventType::kOperationalNetworkEnabled:
  58. ChipLogProgress(DeviceLayer, "OperationalNetworkEnabled");
  59. break;
  60. case DeviceEventType::kDnssdInitialized:
  61. ChipLogProgress(DeviceLayer, "DnssdPlatformInitialized");
  62. break;
  63. }
  64. DeviceAppJNIMgr().PostEvent(event->Type);
  65. }
  66. static int kFabricRemoved = 0x9FFF; // out of public event range (0x8000)
  67. class FabricDelegate : public FabricTable::Delegate
  68. {
  69. void OnFabricRemoved(const FabricTable & fabricTable, FabricIndex fabricIndex) override
  70. {
  71. ChipLogProgress(DeviceLayer, "OnFabricRemoved():FabricCount[%d],FabricIndex[%d]", fabricTable.FabricCount(), fabricIndex);
  72. if (fabricTable.FabricCount() == 0)
  73. {
  74. DeviceAppJNIMgr().PostEvent(kFabricRemoved);
  75. }
  76. }
  77. };
  78. static FabricDelegate gFabricDelegate;
  79. CHIP_ERROR PreServerInit()
  80. {
  81. /**
  82. * Apply any user-defined configurations prior to initializing Server.
  83. *
  84. * Ex.
  85. * DnssdServer::Instance().SetExtendedDiscoveryTimeoutSecs(userTimeoutSecs);
  86. *
  87. */
  88. chip::DeviceLayer::PlatformMgr().AddEventHandler(DeviceEventCallback, reinterpret_cast<intptr_t>(nullptr));
  89. Server::GetInstance().GetFabricTable().AddFabricDelegate(&gFabricDelegate);
  90. return CHIP_NO_ERROR;
  91. }