From a0110136209ecb6948848bef13c485f6141fa331 Mon Sep 17 00:00:00 2001 From: Kamil Kasperczyk Date: Mon, 13 Jun 2022 10:52:20 +0200 Subject: [PATCH 1/2] Move GetVendorId and GetProductId to DeviceInstanceInfoProvider GetVendorId and GetProductId are part of ConfigurationManager, while it can be useful to put those data into the factory data. * Moved GetVendorId and GetProductId to DeviceInstanceInfoProvider * Added DeviceInstanceInfoProviderImpl for the platforms that has different methods implementation than LegacyDeviceInstanceInfoProvider. --- examples/common/pigweed/rpc_services/Device.h | 4 +- src/app/clusters/basic/basic.cpp | 8 +- .../ota-requestor/DefaultOTARequestor.cpp | 6 +- .../ExtendedOTARequestorDriver.cpp | 5 +- src/app/server/Dnssd.cpp | 6 +- src/app/server/OnboardingCodesUtil.cpp | 9 +- src/include/platform/ConfigurationManager.h | 4 - .../platform/DeviceInstanceInfoProvider.h | 44 +++++ .../GenericConfigurationManagerImpl.h | 4 - .../GenericConfigurationManagerImpl.ipp | 83 ++++---- src/lib/shell/commands/Config.cpp | 4 +- src/platform/BUILD.gn | 3 +- src/platform/Darwin/BUILD.gn | 2 + .../Darwin/ConfigurationManagerImpl.cpp | 26 +-- .../Darwin/ConfigurationManagerImpl.h | 3 - .../Darwin/DeviceInstanceInfoProvider.h | 49 +++++ .../Darwin/DeviceInstanceInfoProviderImpl.cpp | 180 ++++++++++++++++++ src/platform/Darwin/PosixConfig.h | 2 +- src/platform/Linux/BUILD.gn | 2 + .../Linux/ConfigurationManagerImpl.cpp | 16 +- src/platform/Linux/ConfigurationManagerImpl.h | 2 - .../Linux/DeviceInstanceInfoProviderImpl.cpp | 160 ++++++++++++++++ .../Linux/DeviceInstanceInfoProviderImpl.h | 49 +++++ src/platform/Linux/PosixConfig.h | 2 +- src/platform/Tizen/BUILD.gn | 2 + .../Tizen/ConfigurationManagerImpl.cpp | 16 +- src/platform/Tizen/ConfigurationManagerImpl.h | 3 - .../Tizen/DeviceInstanceInfoProviderImpl.cpp | 160 ++++++++++++++++ .../Tizen/DeviceInstanceInfoProviderImpl.h | 49 +++++ src/platform/Tizen/PosixConfig.h | 2 +- src/platform/android/AndroidConfig.h | 2 +- src/platform/android/BUILD.gn | 2 + .../android/ConfigurationManagerImpl.cpp | 38 +--- .../android/ConfigurationManagerImpl.h | 2 - .../DeviceInstanceInfoProviderImpl.cpp | 170 +++++++++++++++++ .../android/DeviceInstanceInfoProviderImpl.h | 50 +++++ src/platform/fake/BUILD.gn | 1 + src/platform/fake/ConfigurationManagerImpl.h | 4 - .../fake/DeviceInstanceInfoProviderImpl.h | 49 +++++ src/platform/webos/BUILD.gn | 2 + .../webos/ConfigurationManagerImpl.cpp | 16 +- src/platform/webos/ConfigurationManagerImpl.h | 2 - .../webos/DeviceInstanceInfoProviderImpl.cpp | 160 ++++++++++++++++ .../webos/DeviceInstanceInfoProviderImpl.h | 49 +++++ src/platform/webos/PosixConfig.h | 2 +- 45 files changed, 1282 insertions(+), 172 deletions(-) create mode 100644 src/platform/Darwin/DeviceInstanceInfoProvider.h create mode 100644 src/platform/Darwin/DeviceInstanceInfoProviderImpl.cpp create mode 100644 src/platform/Linux/DeviceInstanceInfoProviderImpl.cpp create mode 100644 src/platform/Linux/DeviceInstanceInfoProviderImpl.h create mode 100644 src/platform/Tizen/DeviceInstanceInfoProviderImpl.cpp create mode 100644 src/platform/Tizen/DeviceInstanceInfoProviderImpl.h create mode 100644 src/platform/android/DeviceInstanceInfoProviderImpl.cpp create mode 100644 src/platform/android/DeviceInstanceInfoProviderImpl.h create mode 100644 src/platform/fake/DeviceInstanceInfoProviderImpl.h create mode 100644 src/platform/webos/DeviceInstanceInfoProviderImpl.cpp create mode 100644 src/platform/webos/DeviceInstanceInfoProviderImpl.h diff --git a/examples/common/pigweed/rpc_services/Device.h b/examples/common/pigweed/rpc_services/Device.h index b3b7508f70bbed..36749f07985a6f 100644 --- a/examples/common/pigweed/rpc_services/Device.h +++ b/examples/common/pigweed/rpc_services/Device.h @@ -112,7 +112,7 @@ class Device : public pw_rpc::nanopb::Device::Service { uint16_t vendor_id; - if (DeviceLayer::ConfigurationMgr().GetVendorId(vendor_id) == CHIP_NO_ERROR) + if (DeviceLayer::GetDeviceInstanceInfoProvider()->GetVendorId(vendor_id) == CHIP_NO_ERROR) { response.vendor_id = static_cast(vendor_id); } @@ -122,7 +122,7 @@ class Device : public pw_rpc::nanopb::Device::Service } uint16_t product_id; - if (DeviceLayer::ConfigurationMgr().GetProductId(product_id) == CHIP_NO_ERROR) + if (DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(product_id) == CHIP_NO_ERROR) { response.product_id = static_cast(product_id); } diff --git a/src/app/clusters/basic/basic.cpp b/src/app/clusters/basic/basic.cpp index c12a0c7bf72c88..7d628459b8cde6 100644 --- a/src/app/clusters/basic/basic.cpp +++ b/src/app/clusters/basic/basic.cpp @@ -91,14 +91,14 @@ CHIP_ERROR BasicAttrAccess::Read(const ConcreteReadAttributePath & aPath, Attrib case VendorName::Id: { constexpr size_t kMaxLen = DeviceLayer::ConfigurationManager::kMaxVendorNameLength; char vendorName[kMaxLen + 1] = { 0 }; - status = ConfigurationMgr().GetVendorName(vendorName, sizeof(vendorName)); + status = GetDeviceInstanceInfoProvider()->GetVendorName(vendorName, sizeof(vendorName)); status = EncodeStringOnSuccess(status, aEncoder, vendorName, kMaxLen); break; } case VendorID::Id: { uint16_t vendorId = 0; - status = ConfigurationMgr().GetVendorId(vendorId); + status = GetDeviceInstanceInfoProvider()->GetVendorId(vendorId); if (status == CHIP_NO_ERROR) { status = aEncoder.Encode(vendorId); @@ -109,14 +109,14 @@ CHIP_ERROR BasicAttrAccess::Read(const ConcreteReadAttributePath & aPath, Attrib case ProductName::Id: { constexpr size_t kMaxLen = DeviceLayer::ConfigurationManager::kMaxProductNameLength; char productName[kMaxLen + 1] = { 0 }; - status = ConfigurationMgr().GetProductName(productName, sizeof(productName)); + status = GetDeviceInstanceInfoProvider()->GetProductName(productName, sizeof(productName)); status = EncodeStringOnSuccess(status, aEncoder, productName, kMaxLen); break; } case ProductID::Id: { uint16_t productId = 0; - status = ConfigurationMgr().GetProductId(productId); + status = GetDeviceInstanceInfoProvider()->GetProductId(productId); if (status == CHIP_NO_ERROR) { status = aEncoder.Encode(productId); diff --git a/src/app/clusters/ota-requestor/DefaultOTARequestor.cpp b/src/app/clusters/ota-requestor/DefaultOTARequestor.cpp index 39aa512596305d..6cdd65f91a1a07 100644 --- a/src/app/clusters/ota-requestor/DefaultOTARequestor.cpp +++ b/src/app/clusters/ota-requestor/DefaultOTARequestor.cpp @@ -565,7 +565,7 @@ void DefaultOTARequestor::NotifyUpdateApplied() { // Log the VersionApplied event uint16_t productId; - if (DeviceLayer::ConfigurationMgr().GetProductId(productId) != CHIP_NO_ERROR) + if (DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(productId) != CHIP_NO_ERROR) { ChipLogError(SoftwareUpdate, "Cannot get Product ID"); RecordErrorUpdateState(CHIP_ERROR_INCORRECT_STATE); @@ -722,10 +722,10 @@ CHIP_ERROR DefaultOTARequestor::SendQueryImageRequest(OperationalDeviceProxy & d QueryImage::Type args; uint16_t vendorId; - ReturnErrorOnFailure(DeviceLayer::ConfigurationMgr().GetVendorId(vendorId)); + ReturnErrorOnFailure(DeviceLayer::GetDeviceInstanceInfoProvider()->GetVendorId(vendorId)); args.vendorId = static_cast(vendorId); - ReturnErrorOnFailure(DeviceLayer::ConfigurationMgr().GetProductId(args.productId)); + ReturnErrorOnFailure(DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(args.productId)); ReturnErrorOnFailure(DeviceLayer::ConfigurationMgr().GetSoftwareVersion(args.softwareVersion)); diff --git a/src/app/clusters/ota-requestor/ExtendedOTARequestorDriver.cpp b/src/app/clusters/ota-requestor/ExtendedOTARequestorDriver.cpp index ba1d0baea170ef..5dff75ad84f79c 100644 --- a/src/app/clusters/ota-requestor/ExtendedOTARequestorDriver.cpp +++ b/src/app/clusters/ota-requestor/ExtendedOTARequestorDriver.cpp @@ -18,6 +18,7 @@ #include "ExtendedOTARequestorDriver.h" #include "OTARequestorInterface.h" #include +#include namespace chip { namespace DeviceLayer { @@ -84,8 +85,8 @@ CHIP_ERROR ExtendedOTARequestorDriver::GetUserConsentSubject(chip::ota::UserCons } subject.requestorNodeId = fabricInfo->GetPeerId().GetNodeId(); - ReturnErrorOnFailure(DeviceLayer::ConfigurationMgr().GetVendorId(subject.requestorVendorId)); - ReturnErrorOnFailure(DeviceLayer::ConfigurationMgr().GetProductId(subject.requestorProductId)); + ReturnErrorOnFailure(DeviceLayer::GetDeviceInstanceInfoProvider()->GetVendorId(subject.requestorVendorId)); + ReturnErrorOnFailure(DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(subject.requestorProductId)); ReturnErrorOnFailure(DeviceLayer::ConfigurationMgr().GetSoftwareVersion(subject.requestorCurrentVersion)); subject.requestorTargetVersion = update.softwareVersion; subject.metadata = update.metadataForRequestor; diff --git a/src/app/server/Dnssd.cpp b/src/app/server/Dnssd.cpp index 664bda2f878fed..b05ef7a3fb07bc 100644 --- a/src/app/server/Dnssd.cpp +++ b/src/app/server/Dnssd.cpp @@ -29,9 +29,9 @@ #include #include #include +#include #include #if CHIP_ENABLE_ROTATING_DEVICE_ID && defined(CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID) -#include #include #endif #include @@ -298,7 +298,7 @@ CHIP_ERROR DnssdServer::Advertise(bool commissionableNode, chip::Dnssd::Commissi uint16_t value; uint32_t val32; - if (DeviceLayer::ConfigurationMgr().GetVendorId(value) != CHIP_NO_ERROR) + if (DeviceLayer::GetDeviceInstanceInfoProvider()->GetVendorId(value) != CHIP_NO_ERROR) { ChipLogDetail(Discovery, "Vendor ID not known"); } @@ -307,7 +307,7 @@ CHIP_ERROR DnssdServer::Advertise(bool commissionableNode, chip::Dnssd::Commissi advertiseParameters.SetVendorId(chip::Optional::Value(value)); } - if (DeviceLayer::ConfigurationMgr().GetProductId(value) != CHIP_NO_ERROR) + if (DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(value) != CHIP_NO_ERROR) { ChipLogDetail(Discovery, "Product ID not known"); } diff --git a/src/app/server/OnboardingCodesUtil.cpp b/src/app/server/OnboardingCodesUtil.cpp index 28451e207dbd36..2d2ce20b5fbfe2 100644 --- a/src/app/server/OnboardingCodesUtil.cpp +++ b/src/app/server/OnboardingCodesUtil.cpp @@ -26,6 +26,7 @@ #include #include #include +#include #include #include @@ -121,17 +122,17 @@ CHIP_ERROR GetPayloadContents(chip::PayloadContents & aPayload, chip::Rendezvous return err; } - err = ConfigurationMgr().GetVendorId(aPayload.vendorID); + err = chip::DeviceLayer::GetDeviceInstanceInfoProvider()->GetVendorId(aPayload.vendorID); if (err != CHIP_NO_ERROR) { - ChipLogError(AppServer, "ConfigurationMgr().GetVendorId() failed: %s", chip::ErrorStr(err)); + ChipLogError(AppServer, "GetDeviceInstanceInfoProvider()->GetVendorId() failed: %s", chip::ErrorStr(err)); return err; } - err = ConfigurationMgr().GetProductId(aPayload.productID); + err = chip::DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(aPayload.productID); if (err != CHIP_NO_ERROR) { - ChipLogError(AppServer, "ConfigurationMgr().GetProductId() failed: %s", chip::ErrorStr(err)); + ChipLogError(AppServer, "GetDeviceInstanceInfoProvider()->GetProductId() failed: %s", chip::ErrorStr(err)); return err; } diff --git a/src/include/platform/ConfigurationManager.h b/src/include/platform/ConfigurationManager.h index 7b3be4d4b6bf4a..5d71e89e1eca51 100644 --- a/src/include/platform/ConfigurationManager.h +++ b/src/include/platform/ConfigurationManager.h @@ -85,10 +85,6 @@ class ConfigurationManager kMaxLanguageTagLength = 5 // ISO 639-1 standard language codes }; - virtual CHIP_ERROR GetVendorName(char * buf, size_t bufSize) = 0; - virtual CHIP_ERROR GetVendorId(uint16_t & vendorId) = 0; - virtual CHIP_ERROR GetProductName(char * buf, size_t bufSize) = 0; - virtual CHIP_ERROR GetProductId(uint16_t & productId) = 0; virtual CHIP_ERROR GetPrimaryMACAddress(MutableByteSpan buf) = 0; virtual CHIP_ERROR GetPrimaryWiFiMACAddress(uint8_t * buf) = 0; virtual CHIP_ERROR GetPrimary802154MACAddress(uint8_t * buf) = 0; diff --git a/src/include/platform/DeviceInstanceInfoProvider.h b/src/include/platform/DeviceInstanceInfoProvider.h index 1735aac4fa9822..872ff93caf0b02 100644 --- a/src/include/platform/DeviceInstanceInfoProvider.h +++ b/src/include/platform/DeviceInstanceInfoProvider.h @@ -28,6 +28,50 @@ class DeviceInstanceInfoProvider DeviceInstanceInfoProvider() = default; virtual ~DeviceInstanceInfoProvider() = default; + /** + * @brief Obtain the Vendor Name from the device's factory data. + * + * @param[in, out] buf Buffer to copy string. + * On CHIP_NO_ERROR return from this function this buffer will be null-terminated. + * On error CHIP_ERROR_BUFFER_TOO_SMALL there is no guarantee that buffer will be null-terminated. + * @param[in] bufSize Size of data, including the null terminator, that can be written to buf. + * This size should be +1 higher than maximum possible string. + * @returns CHIP_NO_ERROR on success, or another CHIP_ERROR from the underlying implementation + * if access fails. + */ + virtual CHIP_ERROR GetVendorName(char * buf, size_t bufSize) = 0; + + /** + * @brief Obtain the Vendor Id from the device's factory data. + * + * @param[out] vendorId Reference to location where the vendor id integer will be copied + * @returns CHIP_NO_ERROR on success, or another CHIP_ERROR from the underlying implementation + * if access fails. + */ + virtual CHIP_ERROR GetVendorId(uint16_t & vendorId) = 0; + + /** + * @brief Obtain the Product Name from the device's factory data. + * + * @param[in, out] buf Buffer to copy string. + * On CHIP_NO_ERROR return from this function this buffer will be null-terminated. + * On error CHIP_ERROR_BUFFER_TOO_SMALL there is no guarantee that buffer will be null-terminated. + * @param[in] bufSize Size of data, including the null terminator, that can be written to buf. + * This size should be +1 higher than maximum possible string. + * @returns CHIP_NO_ERROR on success, or another CHIP_ERROR from the underlying implementation + * if access fails. + */ + virtual CHIP_ERROR GetProductName(char * buf, size_t bufSize) = 0; + + /** + * @brief Obtain the Product Id from the device's factory data. + * + * @param[out] productId Reference to location where the product id integer will be copied + * @returns CHIP_NO_ERROR on success, or another CHIP_ERROR from the underlying implementation + * if access fails. + */ + virtual CHIP_ERROR GetProductId(uint16_t & productId) = 0; + /** * @brief Obtain the Serial Number from the device's factory data. * diff --git a/src/include/platform/internal/GenericConfigurationManagerImpl.h b/src/include/platform/internal/GenericConfigurationManagerImpl.h index db479f90643b00..54277a16205016 100644 --- a/src/include/platform/internal/GenericConfigurationManagerImpl.h +++ b/src/include/platform/internal/GenericConfigurationManagerImpl.h @@ -64,10 +64,6 @@ class GenericConfigurationManagerImpl : public ConfigurationManager // ===== Methods that implement the ConfigurationManager abstract interface. CHIP_ERROR Init() override; - CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; - CHIP_ERROR GetVendorId(uint16_t & vendorId) override; - CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; - CHIP_ERROR GetProductId(uint16_t & productId) override; CHIP_ERROR StoreHardwareVersion(uint16_t hardwareVer) override; CHIP_ERROR GetSoftwareVersionString(char * buf, size_t bufSize) override; CHIP_ERROR GetSoftwareVersion(uint32_t & softwareVer) override; diff --git a/src/include/platform/internal/GenericConfigurationManagerImpl.ipp b/src/include/platform/internal/GenericConfigurationManagerImpl.ipp index 5c3044478626e0..1f3bf31c662914 100644 --- a/src/include/platform/internal/GenericConfigurationManagerImpl.ipp +++ b/src/include/platform/internal/GenericConfigurationManagerImpl.ipp @@ -36,10 +36,10 @@ #include #include #include +#include #include #include #include -#include #include #include @@ -72,6 +72,10 @@ public: mGenericConfigManager(configManager) {} + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; + CHIP_ERROR GetVendorId(uint16_t & vendorId) override; + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; + CHIP_ERROR GetProductId(uint16_t & productId) override; CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override; CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override; CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override; @@ -82,6 +86,37 @@ private: GenericConfigurationManagerImpl & mGenericConfigManager; }; +template +CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetVendorId(uint16_t & vendorId) +{ + vendorId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID); + return CHIP_NO_ERROR; +} + +template +CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetProductId(uint16_t & productId) +{ + productId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_ID); + return CHIP_NO_ERROR; +} + +template +CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetVendorName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); + return CHIP_NO_ERROR; +} + +template +CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetProductName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); + + return CHIP_NO_ERROR; +} + template CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetSerialNumber(char * buf, size_t bufSize) { @@ -109,10 +144,6 @@ CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetSerialNumber(char * template CHIP_ERROR LegacyDeviceInstanceInfoProvider::GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) { -#if CHIP_DEVICE_LAYER_TARGET_FAKE - return CHIP_ERROR_NOT_IMPLEMENTED; -#else - CHIP_ERROR err; enum { @@ -148,7 +179,6 @@ exit: ChipLogError(DeviceLayer, "Invalid manufacturing date: %s", dateStr); } return err; -#endif } template @@ -420,20 +450,6 @@ CHIP_ERROR GenericConfigurationManagerImpl::Init() return err; } -template -CHIP_ERROR GenericConfigurationManagerImpl::GetVendorId(uint16_t & vendorId) -{ - vendorId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID); - return CHIP_NO_ERROR; -} - -template -CHIP_ERROR GenericConfigurationManagerImpl::GetProductId(uint16_t & productId) -{ - productId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_ID); - return CHIP_NO_ERROR; -} - template CHIP_ERROR GenericConfigurationManagerImpl::GetSoftwareVersion(uint32_t & softwareVer) { @@ -462,7 +478,8 @@ CHIP_ERROR GenericConfigurationManagerImpl::GetFirmwareBuildChipEpo const char * date = CHIP_DEVICE_CONFIG_FIRMWARE_BUILD_DATE; const char * time = CHIP_DEVICE_CONFIG_FIRMWARE_BUILD_TIME; uint32_t seconds; - auto good = CalendarToChipEpochTime(COMPUTE_BUILD_YEAR(date), COMPUTE_BUILD_MONTH(date), COMPUTE_BUILD_DAY(date), COMPUTE_BUILD_HOUR(time), COMPUTE_BUILD_MIN(time), COMPUTE_BUILD_SEC(time), seconds); + auto good = CalendarToChipEpochTime(COMPUTE_BUILD_YEAR(date), COMPUTE_BUILD_MONTH(date), COMPUTE_BUILD_DAY(date), + COMPUTE_BUILD_HOUR(time), COMPUTE_BUILD_MIN(time), COMPUTE_BUILD_SEC(time), seconds); if (good) { chipEpochTime = chip::System::Clock::Seconds32(seconds); @@ -504,22 +521,6 @@ CHIP_ERROR GenericConfigurationManagerImpl::GetSecondaryPairingHint return CHIP_NO_ERROR; } -template -CHIP_ERROR GenericConfigurationManagerImpl::GetVendorName(char * buf, size_t bufSize) -{ - ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); - strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); - return CHIP_NO_ERROR; -} - -template -CHIP_ERROR GenericConfigurationManagerImpl::GetProductName(char * buf, size_t bufSize) -{ - ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); - strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); - return CHIP_NO_ERROR; -} - template CHIP_ERROR GenericConfigurationManagerImpl::GetSoftwareVersionString(char * buf, size_t bufSize) { @@ -754,11 +755,11 @@ GenericConfigurationManagerImpl::GetBLEDeviceIdentificationInfo(Ble deviceIdInfo.Init(); - err = GetVendorId(id); + err = GetDeviceInstanceInfoProvider()->GetVendorId(id); SuccessOrExit(err); deviceIdInfo.SetVendorId(id); - err = GetProductId(id); + err = GetDeviceInstanceInfoProvider()->GetProductId(id); SuccessOrExit(err); deviceIdInfo.SetProductId(id); @@ -856,7 +857,7 @@ void GenericConfigurationManagerImpl::LogDeviceConfig() { uint16_t vendorId; - if (GetVendorId(vendorId) != CHIP_NO_ERROR) + if (deviceInstanceInfoProvider->GetVendorId(vendorId) != CHIP_NO_ERROR) { vendorId = 0; } @@ -865,7 +866,7 @@ void GenericConfigurationManagerImpl::LogDeviceConfig() { uint16_t productId; - if (GetProductId(productId) != CHIP_NO_ERROR) + if (deviceInstanceInfoProvider->GetProductId(productId) != CHIP_NO_ERROR) { productId = 0; } diff --git a/src/lib/shell/commands/Config.cpp b/src/lib/shell/commands/Config.cpp index 8582bbefaaee3a..e29327b09fe672 100644 --- a/src/lib/shell/commands/Config.cpp +++ b/src/lib/shell/commands/Config.cpp @@ -45,7 +45,7 @@ static CHIP_ERROR ConfigGetVendorId(bool printHeader) streamer_t * sout = streamer_get(); uint16_t value16; - ReturnErrorOnFailure(ConfigurationMgr().GetVendorId(value16)); + ReturnErrorOnFailure(DeviceLayer::GetDeviceInstanceInfoProvider()->GetVendorId(value16)); if (printHeader) { streamer_printf(sout, "VendorId: "); @@ -64,7 +64,7 @@ static CHIP_ERROR ConfigGetProductId(bool printHeader) streamer_t * sout = streamer_get(); uint16_t value16; - ReturnErrorOnFailure(ConfigurationMgr().GetProductId(value16)); + ReturnErrorOnFailure(DeviceLayer::GetDeviceInstanceInfoProvider()->GetProductId(value16)); if (printHeader) { streamer_printf(sout, "ProductId: "); diff --git a/src/platform/BUILD.gn b/src/platform/BUILD.gn index 3dde9e09081332..84e3e1d484235f 100644 --- a/src/platform/BUILD.gn +++ b/src/platform/BUILD.gn @@ -52,7 +52,8 @@ if (chip_device_platform != "none" && chip_device_platform != "external") { # Enable default/generic test-mode DeviceInstanceInfoProvider in GenericConfigurationManagerImpl # === FOR TRANSITION UNTIL ALL EXAMPLES PROVIDE THEIR OWN === - chip_use_transitional_device_instance_info_provider = true + chip_use_transitional_device_instance_info_provider = + chip_device_platform != "linux" && chip_device_platform != "android" && chip_device_platform != "darwin" && chip_device_platform != "webos" && chip_device_platform != "tizen" # Enable default/generic test-mode CommissionableDataProvider in GenericConfigurationManagerImpl # === FOR TRANSITION UNTIL ALL EXAMPLES PROVIDE THEIR OWN === diff --git a/src/platform/Darwin/BUILD.gn b/src/platform/Darwin/BUILD.gn index 41b7ada922ff64..0bc54f78ca4332 100644 --- a/src/platform/Darwin/BUILD.gn +++ b/src/platform/Darwin/BUILD.gn @@ -47,6 +47,8 @@ static_library("Darwin") { "ConfigurationManagerImpl.h", "ConnectivityManagerImpl.cpp", "ConnectivityManagerImpl.h", + "DeviceInstanceInfoProviderImpl.cpp", + "DeviceInstanceInfoProviderImpl.h", "DiagnosticDataProviderImpl.cpp", "DiagnosticDataProviderImpl.h", "DnssdContexts.cpp", diff --git a/src/platform/Darwin/ConfigurationManagerImpl.cpp b/src/platform/Darwin/ConfigurationManagerImpl.cpp index 6960b1e3be6060..d6eed65d6149b7 100644 --- a/src/platform/Darwin/ConfigurationManagerImpl.cpp +++ b/src/platform/Darwin/ConfigurationManagerImpl.cpp @@ -28,6 +28,7 @@ #include #include #include +#include #include #include #include @@ -153,10 +154,15 @@ CHIP_ERROR ConfigurationManagerImpl::Init() { #if CHIP_DISABLE_PLATFORM_KVS return CHIP_NO_ERROR; -#else // CHIP_DISABLE_PLATFORM_KVS +#else // CHIP_DISABLE_PLATFORM_KVS // Initialize the generic implementation base class. ReturnErrorOnFailure(Internal::GenericConfigurationManagerImpl::Init()); +#if !CHIP_USE_TRANSITIONAL_DEVICE_INSTANCE_INFO_PROVIDER + static DeviceInstanceInfoProviderImpl sDeviceInstanceInfoProvider; + SetDeviceInstanceInfoProvider(&sDeviceInstanceInfoProvider); +#endif + if (!PosixConfig::ConfigValueExists(PosixConfig::kConfigKey_VendorId)) { ReturnErrorOnFailure(StoreVendorId(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID)); @@ -234,24 +240,6 @@ void ConfigurationManagerImpl::InitiateFactoryReset() ChipLogError(DeviceLayer, "InitiateFactoryReset not implemented"); } -CHIP_ERROR ConfigurationManagerImpl::GetVendorId(uint16_t & vendorId) -{ -#if CHIP_DISABLE_PLATFORM_KVS - return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; -#else // CHIP_DISABLE_PLATFORM_KVS - return ReadConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); -#endif // CHIP_DISABLE_PLATFORM_KVS -} - -CHIP_ERROR ConfigurationManagerImpl::GetProductId(uint16_t & productId) -{ -#if CHIP_DISABLE_PLATFORM_KVS - return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; -#else // CHIP_DISABLE_PLATFORM_KVS - return ReadConfigValue(PosixConfig::kConfigKey_ProductId, productId); -#endif // CHIP_DISABLE_PLATFORM_KVS -} - CHIP_ERROR ConfigurationManagerImpl::StoreVendorId(uint16_t vendorId) { #if CHIP_DISABLE_PLATFORM_KVS diff --git a/src/platform/Darwin/ConfigurationManagerImpl.h b/src/platform/Darwin/ConfigurationManagerImpl.h index 533817da522aa1..9caaf4293fd0fd 100644 --- a/src/platform/Darwin/ConfigurationManagerImpl.h +++ b/src/platform/Darwin/ConfigurationManagerImpl.h @@ -41,9 +41,6 @@ class ConfigurationManagerImpl : public Internal::GenericConfigurationManagerImp CHIP_ERROR StoreVendorId(uint16_t vendorId); CHIP_ERROR StoreProductId(uint16_t productId); - CHIP_ERROR GetVendorId(uint16_t & vendorId) override; - CHIP_ERROR GetProductId(uint16_t & productId) override; - // This returns an instance of this class. static ConfigurationManagerImpl & GetDefaultInstance(); diff --git a/src/platform/Darwin/DeviceInstanceInfoProvider.h b/src/platform/Darwin/DeviceInstanceInfoProvider.h new file mode 100644 index 00000000000000..86827f6bd664f6 --- /dev/null +++ b/src/platform/Darwin/DeviceInstanceInfoProvider.h @@ -0,0 +1,49 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#pragma once + +#include + +namespace chip { +namespace DeviceLayer { + +class DeviceInstanceInfoProviderImpl : public chip::DeviceLayer::DeviceInstanceInfoProvider +{ +public: + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; + CHIP_ERROR GetVendorId(uint16_t & vendorId) override; + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; + CHIP_ERROR GetProductId(uint16_t & productId) override; + CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override; + CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override; + CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override; + CHIP_ERROR GetHardwareVersionString(char * buf, size_t bufSize) override; + CHIP_ERROR GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) override; + +private: + friend DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl(); + static DeviceInstanceInfoProviderImpl sInstance; +}; + +inline DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl() +{ + return DeviceInstanceInfoProviderImpl::sInstance; +} +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/Darwin/DeviceInstanceInfoProviderImpl.cpp b/src/platform/Darwin/DeviceInstanceInfoProviderImpl.cpp new file mode 100644 index 00000000000000..a93863a3a76e98 --- /dev/null +++ b/src/platform/Darwin/DeviceInstanceInfoProviderImpl.cpp @@ -0,0 +1,180 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "DeviceInstanceInfoProviderImpl.h" + +#include +#include +#include + +namespace chip { +namespace DeviceLayer { + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorId(uint16_t & vendorId) +{ +#if CHIP_DISABLE_PLATFORM_KVS + return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; +#else // CHIP_DISABLE_PLATFORM_KVS + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_VendorId, vendorId); +#endif // CHIP_DISABLE_PLATFORM_KVS +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductId(uint16_t & productId) +{ +#if CHIP_DISABLE_PLATFORM_KVS + return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; +#else // CHIP_DISABLE_PLATFORM_KVS + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_ProductId, productId); +#endif // CHIP_DISABLE_PLATFORM_KVS +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); + + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetSerialNumber(char * buf, size_t bufSize) +{ +#if CHIP_DISABLE_PLATFORM_KVS + return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; +#else + ChipError err = CHIP_NO_ERROR; + size_t serialNumLen = 0; // without counting null-terminator + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_SerialNum, buf, bufSize, serialNumLen); + +#ifdef CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + if (CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER[0] != 0 && err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ReturnErrorCodeIf(sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) > bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(buf, CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER, sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER)); + serialNumLen = sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) - 1; + } +#endif // CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + ReturnErrorOnFailure(err); + + ReturnErrorCodeIf(serialNumLen >= bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(buf[serialNumLen] != 0, CHIP_ERROR_INVALID_STRING_LENGTH); + + return err; +#endif +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) +{ +#if CHIP_DISABLE_PLATFORM_KVS + return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; +#else + CHIP_ERROR err; + enum + { + kDateStringLength = 10 // YYYY-MM-DD + }; + char dateStr[kDateStringLength + 1]; + size_t dateLen; + char * parseEnd; + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_ManufacturingDate, dateStr, sizeof(dateStr), + dateLen); + SuccessOrExit(err); + + VerifyOrExit(dateLen == kDateStringLength, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 4 digits, so our number can't be bigger than 9999. + year = static_cast(strtoul(dateStr, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 4, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + month = static_cast(strtoul(dateStr + 5, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 7, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + day = static_cast(strtoul(dateStr + 8, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 10, err = CHIP_ERROR_INVALID_ARGUMENT); + +exit: + if (err != CHIP_NO_ERROR && err != CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ChipLogError(DeviceLayer, "Invalid manufacturing date: %s", dateStr); + } + return err; +#endif +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersion(uint16_t & hardwareVersion) +{ +#if CHIP_DISABLE_PLATFORM_KVS + return CHIP_ERROR_UNSUPPORTED_CHIP_FEATURE; +#else + ChipError err = CHIP_NO_ERROR; + uint32_t valInt = 0; + + err = Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_HardwareVersion, valInt); + if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + hardwareVersion = static_cast(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION); + err = CHIP_NO_ERROR; + } + else + { + hardwareVersion = static_cast(valInt); + } + + return err; +#endif +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersionString(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) +{ + ChipError err = CHIP_ERROR_WRONG_KEY_TYPE; +#if CHIP_ENABLE_ROTATING_DEVICE_ID && defined(CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID) + static_assert(ConfigurationManager::kRotatingDeviceIDUniqueIDLength >= ConfigurationManager::kMinRotatingDeviceIDUniqueIDLength, + "Length of unique ID for rotating device ID is smaller than minimum."); + constexpr uint8_t uniqueId[] = CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID; + + ReturnErrorCodeIf(sizeof(uniqueId) > uniqueIdSpan.size(), CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(sizeof(uniqueId) != ConfigurationManager::kRotatingDeviceIDUniqueIDLength, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(uniqueIdSpan.data(), uniqueId, sizeof(uniqueId)); + uniqueIdSpan.reduce_size(sizeof(uniqueId)); + return CHIP_NO_ERROR; +#endif + return err; +} + +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/Darwin/PosixConfig.h b/src/platform/Darwin/PosixConfig.h index ea4a7222568170..fe4c1dd48a4250 100644 --- a/src/platform/Darwin/PosixConfig.h +++ b/src/platform/Darwin/PosixConfig.h @@ -26,7 +26,7 @@ #include #include -#include +#include namespace chip { namespace DeviceLayer { diff --git a/src/platform/Linux/BUILD.gn b/src/platform/Linux/BUILD.gn index 7f46aee3dcfc0b..29c232f2a97159 100644 --- a/src/platform/Linux/BUILD.gn +++ b/src/platform/Linux/BUILD.gn @@ -53,6 +53,8 @@ static_library("Linux") { "ConnectivityManagerImpl.h", "ConnectivityUtils.cpp", "ConnectivityUtils.h", + "DeviceInstanceInfoProviderImpl.cpp", + "DeviceInstanceInfoProviderImpl.h", "DeviceNetworkProvisioningDelegateImpl.cpp", "DeviceNetworkProvisioningDelegateImpl.h", "DiagnosticDataProviderImpl.cpp", diff --git a/src/platform/Linux/ConfigurationManagerImpl.cpp b/src/platform/Linux/ConfigurationManagerImpl.cpp index b0e7b8cfd37b65..03adde331c3efb 100644 --- a/src/platform/Linux/ConfigurationManagerImpl.cpp +++ b/src/platform/Linux/ConfigurationManagerImpl.cpp @@ -34,6 +34,7 @@ #include #include #include +#include #include #include @@ -67,6 +68,11 @@ CHIP_ERROR ConfigurationManagerImpl::Init() err = Internal::GenericConfigurationManagerImpl::Init(); SuccessOrExit(err); +#if !CHIP_USE_TRANSITIONAL_DEVICE_INSTANCE_INFO_PROVIDER + static DeviceInstanceInfoProviderImpl sDeviceInstanceInfoProvider; + SetDeviceInstanceInfoProvider(&sDeviceInstanceInfoProvider); +#endif + if (!PosixConfig::ConfigValueExists(PosixConfig::kConfigKey_VendorId)) { err = StoreVendorId(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID); @@ -327,16 +333,6 @@ void ConfigurationManagerImpl::DoFactoryReset(intptr_t arg) // TODO(#742): restart CHIP exe } -CHIP_ERROR ConfigurationManagerImpl::GetVendorId(uint16_t & vendorId) -{ - return ReadConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); -} - -CHIP_ERROR ConfigurationManagerImpl::GetProductId(uint16_t & productId) -{ - return ReadConfigValue(PosixConfig::kConfigKey_ProductId, productId); -} - CHIP_ERROR ConfigurationManagerImpl::StoreVendorId(uint16_t vendorId) { return WriteConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); diff --git a/src/platform/Linux/ConfigurationManagerImpl.h b/src/platform/Linux/ConfigurationManagerImpl.h index 7ab13fe46f8b1c..866710fc8faac9 100644 --- a/src/platform/Linux/ConfigurationManagerImpl.h +++ b/src/platform/Linux/ConfigurationManagerImpl.h @@ -40,8 +40,6 @@ class ConfigurationManagerImpl : public Internal::GenericConfigurationManagerImp CHIP_ERROR StoreVendorId(uint16_t vendorId); CHIP_ERROR StoreProductId(uint16_t productId); - CHIP_ERROR GetVendorId(uint16_t & vendorId) override; - CHIP_ERROR GetProductId(uint16_t & productId) override; CHIP_ERROR GetRebootCount(uint32_t & rebootCount) override; CHIP_ERROR StoreRebootCount(uint32_t rebootCount) override; CHIP_ERROR GetTotalOperationalHours(uint32_t & totalOperationalHours) override; diff --git a/src/platform/Linux/DeviceInstanceInfoProviderImpl.cpp b/src/platform/Linux/DeviceInstanceInfoProviderImpl.cpp new file mode 100644 index 00000000000000..f278915f984fbe --- /dev/null +++ b/src/platform/Linux/DeviceInstanceInfoProviderImpl.cpp @@ -0,0 +1,160 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "DeviceInstanceInfoProviderImpl.h" + +#include +#include +#include + +namespace chip { +namespace DeviceLayer { + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorId(uint16_t & vendorId) +{ + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_VendorId, vendorId); +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductId(uint16_t & productId) +{ + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_ProductId, productId); +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); + + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetSerialNumber(char * buf, size_t bufSize) +{ + ChipError err = CHIP_NO_ERROR; + size_t serialNumLen = 0; // without counting null-terminator + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_SerialNum, buf, bufSize, serialNumLen); + +#ifdef CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + if (CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER[0] != 0 && err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ReturnErrorCodeIf(sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) > bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(buf, CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER, sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER)); + serialNumLen = sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) - 1; + } +#endif // CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + ReturnErrorOnFailure(err); + + ReturnErrorCodeIf(serialNumLen >= bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(buf[serialNumLen] != 0, CHIP_ERROR_INVALID_STRING_LENGTH); + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) +{ + CHIP_ERROR err; + enum + { + kDateStringLength = 10 // YYYY-MM-DD + }; + char dateStr[kDateStringLength + 1]; + size_t dateLen; + char * parseEnd; + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_ManufacturingDate, dateStr, sizeof(dateStr), + dateLen); + SuccessOrExit(err); + + VerifyOrExit(dateLen == kDateStringLength, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 4 digits, so our number can't be bigger than 9999. + year = static_cast(strtoul(dateStr, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 4, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + month = static_cast(strtoul(dateStr + 5, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 7, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + day = static_cast(strtoul(dateStr + 8, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 10, err = CHIP_ERROR_INVALID_ARGUMENT); + +exit: + if (err != CHIP_NO_ERROR && err != CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ChipLogError(DeviceLayer, "Invalid manufacturing date: %s", dateStr); + } + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersion(uint16_t & hardwareVersion) +{ + ChipError err = CHIP_NO_ERROR; + uint32_t valInt = 0; + + err = Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_HardwareVersion, valInt); + if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + hardwareVersion = static_cast(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION); + err = CHIP_NO_ERROR; + } + else + { + hardwareVersion = static_cast(valInt); + } + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersionString(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) +{ + ChipError err = CHIP_ERROR_WRONG_KEY_TYPE; +#if CHIP_ENABLE_ROTATING_DEVICE_ID && defined(CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID) + static_assert(ConfigurationManager::kRotatingDeviceIDUniqueIDLength >= ConfigurationManager::kMinRotatingDeviceIDUniqueIDLength, + "Length of unique ID for rotating device ID is smaller than minimum."); + constexpr uint8_t uniqueId[] = CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID; + + ReturnErrorCodeIf(sizeof(uniqueId) > uniqueIdSpan.size(), CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(sizeof(uniqueId) != ConfigurationManager::kRotatingDeviceIDUniqueIDLength, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(uniqueIdSpan.data(), uniqueId, sizeof(uniqueId)); + uniqueIdSpan.reduce_size(sizeof(uniqueId)); + return CHIP_NO_ERROR; +#endif + return err; +} + +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/Linux/DeviceInstanceInfoProviderImpl.h b/src/platform/Linux/DeviceInstanceInfoProviderImpl.h new file mode 100644 index 00000000000000..86827f6bd664f6 --- /dev/null +++ b/src/platform/Linux/DeviceInstanceInfoProviderImpl.h @@ -0,0 +1,49 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#pragma once + +#include + +namespace chip { +namespace DeviceLayer { + +class DeviceInstanceInfoProviderImpl : public chip::DeviceLayer::DeviceInstanceInfoProvider +{ +public: + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; + CHIP_ERROR GetVendorId(uint16_t & vendorId) override; + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; + CHIP_ERROR GetProductId(uint16_t & productId) override; + CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override; + CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override; + CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override; + CHIP_ERROR GetHardwareVersionString(char * buf, size_t bufSize) override; + CHIP_ERROR GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) override; + +private: + friend DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl(); + static DeviceInstanceInfoProviderImpl sInstance; +}; + +inline DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl() +{ + return DeviceInstanceInfoProviderImpl::sInstance; +} +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/Linux/PosixConfig.h b/src/platform/Linux/PosixConfig.h index c2965e2ea8b205..e8370a3e1c0a72 100644 --- a/src/platform/Linux/PosixConfig.h +++ b/src/platform/Linux/PosixConfig.h @@ -26,7 +26,7 @@ #include #include -#include +#include namespace chip { namespace DeviceLayer { diff --git a/src/platform/Tizen/BUILD.gn b/src/platform/Tizen/BUILD.gn index dd876b6ad8fe1b..825224b90e1417 100644 --- a/src/platform/Tizen/BUILD.gn +++ b/src/platform/Tizen/BUILD.gn @@ -41,6 +41,8 @@ static_library("Tizen") { "ConfigurationManagerImpl.h", "ConnectivityManagerImpl.cpp", "ConnectivityManagerImpl.h", + "DeviceInstanceInfoProviderImpl.cpp", + "DeviceInstanceInfoProviderImpl.h", "DeviceNetworkProvisioningDelegateImpl.cpp", "DeviceNetworkProvisioningDelegateImpl.h", "DiagnosticDataProviderImpl.cpp", diff --git a/src/platform/Tizen/ConfigurationManagerImpl.cpp b/src/platform/Tizen/ConfigurationManagerImpl.cpp index 01e448f3255d6f..95bff98fc36a73 100644 --- a/src/platform/Tizen/ConfigurationManagerImpl.cpp +++ b/src/platform/Tizen/ConfigurationManagerImpl.cpp @@ -30,6 +30,7 @@ #include #include #include +#include #include #include #include @@ -52,6 +53,11 @@ CHIP_ERROR ConfigurationManagerImpl::Init(void) error = Internal::GenericConfigurationManagerImpl::Init(); SuccessOrExit(error); +#if !CHIP_USE_TRANSITIONAL_DEVICE_INSTANCE_INFO_PROVIDER + static DeviceInstanceInfoProviderImpl sDeviceInstanceInfoProvider; + SetDeviceInstanceInfoProvider(&sDeviceInstanceInfoProvider); +#endif + if (!PosixConfig::ConfigValueExists(PosixConfig::kConfigKey_VendorId)) { error = StoreVendorId(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID); @@ -70,16 +76,6 @@ CHIP_ERROR ConfigurationManagerImpl::Init(void) return error; } -CHIP_ERROR ConfigurationManagerImpl::GetVendorId(uint16_t & vendorId) -{ - return ReadConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); -} - -CHIP_ERROR ConfigurationManagerImpl::GetProductId(uint16_t & productId) -{ - return ReadConfigValue(PosixConfig::kConfigKey_ProductId, productId); -} - CHIP_ERROR ConfigurationManagerImpl::StoreVendorId(uint16_t vendorId) { return WriteConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); diff --git a/src/platform/Tizen/ConfigurationManagerImpl.h b/src/platform/Tizen/ConfigurationManagerImpl.h index a1da1f7e60f7a8..779fa93518a6a9 100644 --- a/src/platform/Tizen/ConfigurationManagerImpl.h +++ b/src/platform/Tizen/ConfigurationManagerImpl.h @@ -40,9 +40,6 @@ class ConfigurationManagerImpl : public Internal::GenericConfigurationManagerImp CHIP_ERROR StoreVendorId(uint16_t vendorId); CHIP_ERROR StoreProductId(uint16_t productId); - CHIP_ERROR GetVendorId(uint16_t & vendorId) override; - CHIP_ERROR GetProductId(uint16_t & productId) override; - // This returns an instance of this class. static ConfigurationManagerImpl & GetDefaultInstance(); diff --git a/src/platform/Tizen/DeviceInstanceInfoProviderImpl.cpp b/src/platform/Tizen/DeviceInstanceInfoProviderImpl.cpp new file mode 100644 index 00000000000000..b56ad4e49d2dd4 --- /dev/null +++ b/src/platform/Tizen/DeviceInstanceInfoProviderImpl.cpp @@ -0,0 +1,160 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "DeviceInstanceInfoProviderImpl.h" + +#include +#include +#include + +namespace chip { +namespace DeviceLayer { + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorId(uint16_t & vendorId) +{ + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_VendorId, vendorId); +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductId(uint16_t & productId) +{ + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_ProductId, productId); +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); + + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetSerialNumber(char * buf, size_t bufSize) +{ + ChipError err = CHIP_NO_ERROR; + size_t serialNumLen = 0; // without counting null-terminator + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_SerialNum, buf, bufSize, serialNumLen); + +#ifdef CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + if (CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER[0] != 0 && err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ReturnErrorCodeIf(sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) > bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(buf, CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER, sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER)); + serialNumLen = sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) - 1; + } +#endif // CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + ReturnErrorOnFailure(err); + + ReturnErrorCodeIf(serialNumLen >= bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(buf[serialNumLen] != 0, CHIP_ERROR_INVALID_STRING_LENGTH); + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) +{ + CHIP_ERROR err; + enum + { + kDateStringLength = 10 // YYYY-MM-DD + }; + char dateStr[kDateStringLength + 1]; + size_t dateLen; + char * parseEnd; + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_ManufacturingDate, dateStr, sizeof(dateStr), + dateLen); + SuccessOrExit(err); + + VerifyOrExit(dateLen == kDateStringLength, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 4 digits, so our number can't be bigger than 9999. + year = static_cast(strtoul(dateStr, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 4, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + month = static_cast(strtoul(dateStr + 5, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 7, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + day = static_cast(strtoul(dateStr + 8, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 10, err = CHIP_ERROR_INVALID_ARGUMENT); + +exit: + if (err != CHIP_NO_ERROR && err != CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ChipLogError(DeviceLayer, "Invalid manufacturing date: %s", dateStr); + } + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersion(uint16_t & hardwareVersion) +{ + ChipError err; + uint32_t valInt = 0; + + err = Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_HardwareVersion, valInt); + if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + hardwareVersion = static_cast(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION); + err = CHIP_NO_ERROR; + } + else + { + hardwareVersion = static_cast(valInt); + } + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersionString(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) +{ + ChipError err = CHIP_ERROR_WRONG_KEY_TYPE; +#if CHIP_ENABLE_ROTATING_DEVICE_ID && defined(CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID) + static_assert(ConfigurationManager::kRotatingDeviceIDUniqueIDLength >= ConfigurationManager::kMinRotatingDeviceIDUniqueIDLength, + "Length of unique ID for rotating device ID is smaller than minimum."); + constexpr uint8_t uniqueId[] = CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID; + + ReturnErrorCodeIf(sizeof(uniqueId) > uniqueIdSpan.size(), CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(sizeof(uniqueId) != ConfigurationManager::kRotatingDeviceIDUniqueIDLength, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(uniqueIdSpan.data(), uniqueId, sizeof(uniqueId)); + uniqueIdSpan.reduce_size(sizeof(uniqueId)); + return CHIP_NO_ERROR; +#endif + return err; +} + +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/Tizen/DeviceInstanceInfoProviderImpl.h b/src/platform/Tizen/DeviceInstanceInfoProviderImpl.h new file mode 100644 index 00000000000000..86827f6bd664f6 --- /dev/null +++ b/src/platform/Tizen/DeviceInstanceInfoProviderImpl.h @@ -0,0 +1,49 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#pragma once + +#include + +namespace chip { +namespace DeviceLayer { + +class DeviceInstanceInfoProviderImpl : public chip::DeviceLayer::DeviceInstanceInfoProvider +{ +public: + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; + CHIP_ERROR GetVendorId(uint16_t & vendorId) override; + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; + CHIP_ERROR GetProductId(uint16_t & productId) override; + CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override; + CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override; + CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override; + CHIP_ERROR GetHardwareVersionString(char * buf, size_t bufSize) override; + CHIP_ERROR GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) override; + +private: + friend DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl(); + static DeviceInstanceInfoProviderImpl sInstance; +}; + +inline DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl() +{ + return DeviceInstanceInfoProviderImpl::sInstance; +} +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/Tizen/PosixConfig.h b/src/platform/Tizen/PosixConfig.h index aa5203bf989f7e..459dd98c2ae9c9 100644 --- a/src/platform/Tizen/PosixConfig.h +++ b/src/platform/Tizen/PosixConfig.h @@ -26,7 +26,7 @@ #include #include -#include +#include namespace chip { namespace DeviceLayer { diff --git a/src/platform/android/AndroidConfig.h b/src/platform/android/AndroidConfig.h index 2d265ca6b9b6b7..d6f446d0fc4ee6 100644 --- a/src/platform/android/AndroidConfig.h +++ b/src/platform/android/AndroidConfig.h @@ -27,7 +27,7 @@ #include #include -#include +#include namespace chip { namespace DeviceLayer { diff --git a/src/platform/android/BUILD.gn b/src/platform/android/BUILD.gn index 510f5de71dd3c3..5e07ce67fca319 100644 --- a/src/platform/android/BUILD.gn +++ b/src/platform/android/BUILD.gn @@ -42,6 +42,8 @@ static_library("android") { "ConfigurationManagerImpl.h", "ConnectivityManagerImpl.cpp", "ConnectivityManagerImpl.h", + "DeviceInstanceInfoProviderImpl.cpp", + "DeviceInstanceInfoProviderImpl.h", "DeviceNetworkProvisioningDelegateImpl.cpp", "DeviceNetworkProvisioningDelegateImpl.h", "DiagnosticDataProviderImpl.cpp", diff --git a/src/platform/android/ConfigurationManagerImpl.cpp b/src/platform/android/ConfigurationManagerImpl.cpp index f8d69be236fcc6..3718ec8ce3302d 100644 --- a/src/platform/android/ConfigurationManagerImpl.cpp +++ b/src/platform/android/ConfigurationManagerImpl.cpp @@ -35,6 +35,7 @@ #include #include #include +#include #include namespace chip { @@ -55,6 +56,11 @@ void ConfigurationManagerImpl::InitializeWithObject(jobject managerObject) jclass configurationManagerClass = env->GetObjectClass(mConfigurationManagerObject); VerifyOrReturn(configurationManagerClass != nullptr, ChipLogError(DeviceLayer, "Failed to get KVS Java class")); +#if !CHIP_USE_TRANSITIONAL_DEVICE_INSTANCE_INFO_PROVIDER + static DeviceInstanceInfoProviderImpl sDeviceInstanceInfoProvider; + SetDeviceInstanceInfoProvider(&sDeviceInstanceInfoProvider); +#endif + AndroidConfig::InitializeWithObject(managerObject); } @@ -158,38 +164,6 @@ void ConfigurationManagerImpl::DoFactoryReset(intptr_t arg) return; } -CHIP_ERROR ConfigurationManagerImpl::GetProductId(uint16_t & productId) -{ - CHIP_ERROR err; - uint32_t u32ProductId = 0; - err = ReadConfigValue(AndroidConfig::kConfigKey_ProductId, u32ProductId); - - if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) - { - productId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_ID); - } - else - { - productId = static_cast(u32ProductId); - } - - return CHIP_NO_ERROR; -} - -CHIP_ERROR ConfigurationManagerImpl::GetProductName(char * buf, size_t bufSize) -{ - CHIP_ERROR err; - size_t productNameSize = 0; // without counting null-terminator - err = ReadConfigValueStr(AndroidConfig::kConfigKey_ProductName, buf, bufSize, productNameSize); - if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) - { - ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); - strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); - } - - return CHIP_NO_ERROR; -} - CHIP_ERROR ConfigurationManagerImpl::GetSoftwareVersion(uint32_t & softwareVer) { CHIP_ERROR err; diff --git a/src/platform/android/ConfigurationManagerImpl.h b/src/platform/android/ConfigurationManagerImpl.h index c28c246d3ec534..45b93bdc76b618 100644 --- a/src/platform/android/ConfigurationManagerImpl.h +++ b/src/platform/android/ConfigurationManagerImpl.h @@ -40,8 +40,6 @@ class ConfigurationManagerImpl : public Internal::GenericConfigurationManagerImp public: void InitializeWithObject(jobject managerObject); static ConfigurationManagerImpl & GetDefaultInstance(); - CHIP_ERROR GetProductId(uint16_t & productId) override; - CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; CHIP_ERROR GetSoftwareVersionString(char * buf, size_t bufSize) override; CHIP_ERROR GetSoftwareVersion(uint32_t & softwareVer) override; CHIP_ERROR GetPartNumber(char * buf, size_t bufSize) override; diff --git a/src/platform/android/DeviceInstanceInfoProviderImpl.cpp b/src/platform/android/DeviceInstanceInfoProviderImpl.cpp new file mode 100644 index 00000000000000..e71f2642890355 --- /dev/null +++ b/src/platform/android/DeviceInstanceInfoProviderImpl.cpp @@ -0,0 +1,170 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "DeviceInstanceInfoProviderImpl.h" + +#include +#include +#include + +namespace chip { +namespace DeviceLayer { + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersionString(char * buf, size_t bufSize) +{ + CHIP_ERROR err; + size_t hardwareVersionLen = 0; // without counting null-terminator + err = Internal::AndroidConfig::ReadConfigValueStr(Internal::AndroidConfig::kConfigKey_HardwareVersionString, buf, bufSize, + hardwareVersionLen); + if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING); + } + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorId(uint16_t & vendorId) +{ + vendorId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductId(uint16_t & productId) +{ + productId = static_cast(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_ID); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); + + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetSerialNumber(char * buf, size_t bufSize) +{ + ChipError err = CHIP_NO_ERROR; + size_t serialNumLen = 0; // without counting null-terminator + + err = Internal::AndroidConfig::ReadConfigValueStr(Internal::AndroidConfig::kConfigKey_SerialNum, buf, bufSize, serialNumLen); + +#ifdef CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + if (CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER[0] != 0 && err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ReturnErrorCodeIf(sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) > bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(buf, CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER, sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER)); + serialNumLen = sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) - 1; + } +#endif // CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + ReturnErrorOnFailure(err); + + ReturnErrorCodeIf(serialNumLen >= bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(buf[serialNumLen] != 0, CHIP_ERROR_INVALID_STRING_LENGTH); + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) +{ + CHIP_ERROR err; + enum + { + kDateStringLength = 10 // YYYY-MM-DD + }; + char dateStr[kDateStringLength + 1]; + size_t dateLen; + char * parseEnd; + + err = Internal::AndroidConfig::ReadConfigValueStr(Internal::AndroidConfig::kConfigKey_ManufacturingDate, dateStr, + sizeof(dateStr), dateLen); + SuccessOrExit(err); + + VerifyOrExit(dateLen == kDateStringLength, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 4 digits, so our number can't be bigger than 9999. + year = static_cast(strtoul(dateStr, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 4, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + month = static_cast(strtoul(dateStr + 5, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 7, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + day = static_cast(strtoul(dateStr + 8, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 10, err = CHIP_ERROR_INVALID_ARGUMENT); + +exit: + if (err != CHIP_NO_ERROR && err != CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ChipLogError(DeviceLayer, "Invalid manufacturing date: %s", dateStr); + } + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersion(uint16_t & hardwareVersion) +{ + ChipError err = CHIP_NO_ERROR; + uint32_t valInt = 0; + + err = Internal::AndroidConfig::ReadConfigValue(Internal::AndroidConfig::kConfigKey_HardwareVersion, valInt); + if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + hardwareVersion = static_cast(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION); + err = CHIP_NO_ERROR; + } + else + { + hardwareVersion = static_cast(valInt); + } + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) +{ + ChipError err = CHIP_ERROR_WRONG_KEY_TYPE; +#if CHIP_ENABLE_ROTATING_DEVICE_ID && defined(CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID) + static_assert(ConfigurationManager::kRotatingDeviceIDUniqueIDLength >= ConfigurationManager::kMinRotatingDeviceIDUniqueIDLength, + "Length of unique ID for rotating device ID is smaller than minimum."); + constexpr uint8_t uniqueId[] = CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID; + + ReturnErrorCodeIf(sizeof(uniqueId) > uniqueIdSpan.size(), CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(sizeof(uniqueId) != ConfigurationManager::kRotatingDeviceIDUniqueIDLength, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(uniqueIdSpan.data(), uniqueId, sizeof(uniqueId)); + uniqueIdSpan.reduce_size(sizeof(uniqueId)); + return CHIP_NO_ERROR; +#endif + return err; +} + +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/android/DeviceInstanceInfoProviderImpl.h b/src/platform/android/DeviceInstanceInfoProviderImpl.h new file mode 100644 index 00000000000000..d7ecdfca158911 --- /dev/null +++ b/src/platform/android/DeviceInstanceInfoProviderImpl.h @@ -0,0 +1,50 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#pragma once + +#include + +namespace chip { +namespace DeviceLayer { + +class DeviceInstanceInfoProviderImpl : public chip::DeviceLayer::DeviceInstanceInfoProvider +{ +public: + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; + CHIP_ERROR GetVendorId(uint16_t & vendorId) override; + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; + CHIP_ERROR GetProductId(uint16_t & productId) override; + CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override; + CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override; + CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override; + CHIP_ERROR GetHardwareVersionString(char * buf, size_t bufSize) override; + CHIP_ERROR GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) override; + +private: + friend DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl(); + static DeviceInstanceInfoProviderImpl sInstance; +}; + +inline DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl() +{ + return DeviceInstanceInfoProviderImpl::sInstance; +} + +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/fake/BUILD.gn b/src/platform/fake/BUILD.gn index ad2a45b51ea2fb..ab4fe755a1cfb9 100644 --- a/src/platform/fake/BUILD.gn +++ b/src/platform/fake/BUILD.gn @@ -25,6 +25,7 @@ static_library("fake") { "ConfigurationManagerImpl.h", "ConnectivityManagerImpl.cpp", "ConnectivityManagerImpl.h", + "DeviceInstanceInfoProviderImpl.h", "DiagnosticDataProviderImpl.cpp", "DiagnosticDataProviderImpl.h", "DnssdImpl.cpp", diff --git a/src/platform/fake/ConfigurationManagerImpl.h b/src/platform/fake/ConfigurationManagerImpl.h index f01d29f61465a9..40f53e0d0f3c9d 100644 --- a/src/platform/fake/ConfigurationManagerImpl.h +++ b/src/platform/fake/ConfigurationManagerImpl.h @@ -35,10 +35,6 @@ class ConfigurationManagerImpl : public ConfigurationManager private: CHIP_ERROR Init() override { return CHIP_NO_ERROR; } - CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } - CHIP_ERROR GetVendorId(uint16_t & vendorId) override { return CHIP_ERROR_NOT_IMPLEMENTED; } - CHIP_ERROR GetProductName(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } - CHIP_ERROR GetProductId(uint16_t & productId) override { return CHIP_ERROR_NOT_IMPLEMENTED; } CHIP_ERROR StoreHardwareVersion(uint16_t hardwareVer) override { return CHIP_ERROR_NOT_IMPLEMENTED; } CHIP_ERROR GetSoftwareVersionString(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } CHIP_ERROR GetFirmwareBuildChipEpochTime(System::Clock::Seconds32 & buildTime) override diff --git a/src/platform/fake/DeviceInstanceInfoProviderImpl.h b/src/platform/fake/DeviceInstanceInfoProviderImpl.h new file mode 100644 index 00000000000000..7032b7e6414bf0 --- /dev/null +++ b/src/platform/fake/DeviceInstanceInfoProviderImpl.h @@ -0,0 +1,49 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#pragma once + +#include + +namespace chip { +namespace DeviceLayer { + +class DeviceInstanceInfoProviderImpl : public chip::DeviceLayer::DeviceInstanceInfoProvider +{ +public: + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetVendorId(uint16_t & vendorId) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetProductId(uint16_t & productId) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetHardwareVersionString(char * buf, size_t bufSize) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + CHIP_ERROR GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) override { return CHIP_ERROR_NOT_IMPLEMENTED; } + +private: + friend DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl(); + static DeviceInstanceInfoProviderImpl sInstance; +}; + +inline DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl() +{ + return DeviceInstanceInfoProviderImpl::sInstance; +} +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/webos/BUILD.gn b/src/platform/webos/BUILD.gn index cd837a03736c9f..06323b323528af 100644 --- a/src/platform/webos/BUILD.gn +++ b/src/platform/webos/BUILD.gn @@ -80,6 +80,8 @@ static_library("webos") { "ConnectivityUtils.h", "DeviceInfoProviderImpl.cpp", "DeviceInfoProviderImpl.h", + "DeviceInstanceInfoProviderImpl.cpp", + "DeviceInstanceInfoProviderImpl.h", "DeviceNetworkProvisioningDelegateImpl.cpp", "DeviceNetworkProvisioningDelegateImpl.h", "DiagnosticDataProviderImpl.cpp", diff --git a/src/platform/webos/ConfigurationManagerImpl.cpp b/src/platform/webos/ConfigurationManagerImpl.cpp index a302ca0082c24b..ba3af60ebbd142 100644 --- a/src/platform/webos/ConfigurationManagerImpl.cpp +++ b/src/platform/webos/ConfigurationManagerImpl.cpp @@ -35,6 +35,7 @@ #include #include #include +#include #include namespace chip { @@ -65,6 +66,11 @@ CHIP_ERROR ConfigurationManagerImpl::Init() err = Internal::GenericConfigurationManagerImpl::Init(); SuccessOrExit(err); +#if !CHIP_USE_TRANSITIONAL_DEVICE_INSTANCE_INFO_PROVIDER + static DeviceInstanceInfoProviderImpl sDeviceInstanceInfoProvider; + SetDeviceInstanceInfoProvider(&sDeviceInstanceInfoProvider); +#endif + if (!PosixConfig::ConfigValueExists(PosixConfig::kConfigKey_VendorId)) { err = StoreVendorId(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_ID); @@ -320,16 +326,6 @@ void ConfigurationManagerImpl::DoFactoryReset(intptr_t arg) // TODO(#742): restart CHIP exe } -CHIP_ERROR ConfigurationManagerImpl::GetVendorId(uint16_t & vendorId) -{ - return ReadConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); -} - -CHIP_ERROR ConfigurationManagerImpl::GetProductId(uint16_t & productId) -{ - return ReadConfigValue(PosixConfig::kConfigKey_ProductId, productId); -} - CHIP_ERROR ConfigurationManagerImpl::StoreVendorId(uint16_t vendorId) { return WriteConfigValue(PosixConfig::kConfigKey_VendorId, vendorId); diff --git a/src/platform/webos/ConfigurationManagerImpl.h b/src/platform/webos/ConfigurationManagerImpl.h index 12cbef9a9c347f..178fd6135fd758 100644 --- a/src/platform/webos/ConfigurationManagerImpl.h +++ b/src/platform/webos/ConfigurationManagerImpl.h @@ -40,8 +40,6 @@ class ConfigurationManagerImpl : public Internal::GenericConfigurationManagerImp CHIP_ERROR StoreVendorId(uint16_t vendorId); CHIP_ERROR StoreProductId(uint16_t productId); - CHIP_ERROR GetVendorId(uint16_t & vendorId) override; - CHIP_ERROR GetProductId(uint16_t & productId) override; CHIP_ERROR GetRebootCount(uint32_t & rebootCount) override; CHIP_ERROR StoreRebootCount(uint32_t rebootCount) override; CHIP_ERROR GetTotalOperationalHours(uint32_t & totalOperationalHours) override; diff --git a/src/platform/webos/DeviceInstanceInfoProviderImpl.cpp b/src/platform/webos/DeviceInstanceInfoProviderImpl.cpp new file mode 100644 index 00000000000000..a8ded8316dcc6d --- /dev/null +++ b/src/platform/webos/DeviceInstanceInfoProviderImpl.cpp @@ -0,0 +1,160 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "DeviceInstanceInfoProviderImpl.h" + +#include +#include +#include + +namespace chip { +namespace DeviceLayer { + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorId(uint16_t & vendorId) +{ + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_VendorId, vendorId); +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductId(uint16_t & productId) +{ + return Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_ProductId, productId); +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetVendorName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_VENDOR_NAME); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetProductName(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEVICE_PRODUCT_NAME); + + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetSerialNumber(char * buf, size_t bufSize) +{ + ChipError err = CHIP_NO_ERROR; + size_t serialNumLen = 0; // without counting null-terminator + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_SerialNum, buf, bufSize, serialNumLen); + +#ifdef CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + if (CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER[0] != 0 && err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ReturnErrorCodeIf(sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) > bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(buf, CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER, sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER)); + serialNumLen = sizeof(CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER) - 1; + } +#endif // CHIP_DEVICE_CONFIG_TEST_SERIAL_NUMBER + ReturnErrorOnFailure(err); + + ReturnErrorCodeIf(serialNumLen >= bufSize, CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(buf[serialNumLen] != 0, CHIP_ERROR_INVALID_STRING_LENGTH); + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) +{ + CHIP_ERROR err; + enum + { + kDateStringLength = 10 // YYYY-MM-DD + }; + char dateStr[kDateStringLength + 1]; + size_t dateLen; + char * parseEnd; + + err = Internal::PosixConfig::ReadConfigValueStr(Internal::PosixConfig::kConfigKey_ManufacturingDate, dateStr, sizeof(dateStr), + dateLen); + SuccessOrExit(err); + + VerifyOrExit(dateLen == kDateStringLength, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 4 digits, so our number can't be bigger than 9999. + year = static_cast(strtoul(dateStr, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 4, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + month = static_cast(strtoul(dateStr + 5, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 7, err = CHIP_ERROR_INVALID_ARGUMENT); + + // Cast does not lose information, because we then check that we only parsed + // 2 digits, so our number can't be bigger than 99. + day = static_cast(strtoul(dateStr + 8, &parseEnd, 10)); + VerifyOrExit(parseEnd == dateStr + 10, err = CHIP_ERROR_INVALID_ARGUMENT); + +exit: + if (err != CHIP_NO_ERROR && err != CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + ChipLogError(DeviceLayer, "Invalid manufacturing date: %s", dateStr); + } + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersion(uint16_t & hardwareVersion) +{ + ChipError err = CHIP_NO_ERROR; + uint32_t valInt = 0; + + err = Internal::PosixConfig::ReadConfigValue(Internal::PosixConfig::kConfigKey_HardwareVersion, valInt); + if (err == CHIP_DEVICE_ERROR_CONFIG_NOT_FOUND) + { + hardwareVersion = static_cast(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION); + err = CHIP_NO_ERROR; + } + else + { + hardwareVersion = static_cast(valInt); + } + + return err; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetHardwareVersionString(char * buf, size_t bufSize) +{ + ReturnErrorCodeIf(bufSize < sizeof(CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING), CHIP_ERROR_BUFFER_TOO_SMALL); + strcpy(buf, CHIP_DEVICE_CONFIG_DEFAULT_DEVICE_HARDWARE_VERSION_STRING); + return CHIP_NO_ERROR; +} + +CHIP_ERROR DeviceInstanceInfoProviderImpl::GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) +{ + ChipError err = CHIP_ERROR_WRONG_KEY_TYPE; +#if CHIP_ENABLE_ROTATING_DEVICE_ID && defined(CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID) + static_assert(ConfigurationManager::kRotatingDeviceIDUniqueIDLength >= ConfigurationManager::kMinRotatingDeviceIDUniqueIDLength, + "Length of unique ID for rotating device ID is smaller than minimum."); + constexpr uint8_t uniqueId[] = CHIP_DEVICE_CONFIG_ROTATING_DEVICE_ID_UNIQUE_ID; + + ReturnErrorCodeIf(sizeof(uniqueId) > uniqueIdSpan.size(), CHIP_ERROR_BUFFER_TOO_SMALL); + ReturnErrorCodeIf(sizeof(uniqueId) != ConfigurationManager::kRotatingDeviceIDUniqueIDLength, CHIP_ERROR_BUFFER_TOO_SMALL); + memcpy(uniqueIdSpan.data(), uniqueId, sizeof(uniqueId)); + uniqueIdSpan.reduce_size(sizeof(uniqueId)); + return CHIP_NO_ERROR; +#endif + return err; +} + +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/webos/DeviceInstanceInfoProviderImpl.h b/src/platform/webos/DeviceInstanceInfoProviderImpl.h new file mode 100644 index 00000000000000..86827f6bd664f6 --- /dev/null +++ b/src/platform/webos/DeviceInstanceInfoProviderImpl.h @@ -0,0 +1,49 @@ +/* + * + * Copyright (c) 2022 Project CHIP Authors + * All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#pragma once + +#include + +namespace chip { +namespace DeviceLayer { + +class DeviceInstanceInfoProviderImpl : public chip::DeviceLayer::DeviceInstanceInfoProvider +{ +public: + CHIP_ERROR GetVendorName(char * buf, size_t bufSize) override; + CHIP_ERROR GetVendorId(uint16_t & vendorId) override; + CHIP_ERROR GetProductName(char * buf, size_t bufSize) override; + CHIP_ERROR GetProductId(uint16_t & productId) override; + CHIP_ERROR GetSerialNumber(char * buf, size_t bufSize) override; + CHIP_ERROR GetManufacturingDate(uint16_t & year, uint8_t & month, uint8_t & day) override; + CHIP_ERROR GetHardwareVersion(uint16_t & hardwareVersion) override; + CHIP_ERROR GetHardwareVersionString(char * buf, size_t bufSize) override; + CHIP_ERROR GetRotatingDeviceIdUniqueId(MutableByteSpan & uniqueIdSpan) override; + +private: + friend DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl(); + static DeviceInstanceInfoProviderImpl sInstance; +}; + +inline DeviceInstanceInfoProviderImpl & DeviceInstanceInfoProviderMgrImpl() +{ + return DeviceInstanceInfoProviderImpl::sInstance; +} +} // namespace DeviceLayer +} // namespace chip diff --git a/src/platform/webos/PosixConfig.h b/src/platform/webos/PosixConfig.h index 44823124667f3b..a7cd7028608421 100644 --- a/src/platform/webos/PosixConfig.h +++ b/src/platform/webos/PosixConfig.h @@ -26,7 +26,7 @@ #include #include -#include +#include namespace chip { namespace DeviceLayer { From c6680a2d82e810ec2a1a43881e90196574122e54 Mon Sep 17 00:00:00 2001 From: "Restyled.io" Date: Mon, 13 Jun 2022 09:00:00 +0000 Subject: [PATCH 2/2] Restyled by gn --- src/platform/BUILD.gn | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/platform/BUILD.gn b/src/platform/BUILD.gn index 84e3e1d484235f..c5bcf15623d895 100644 --- a/src/platform/BUILD.gn +++ b/src/platform/BUILD.gn @@ -53,7 +53,9 @@ if (chip_device_platform != "none" && chip_device_platform != "external") { # Enable default/generic test-mode DeviceInstanceInfoProvider in GenericConfigurationManagerImpl # === FOR TRANSITION UNTIL ALL EXAMPLES PROVIDE THEIR OWN === chip_use_transitional_device_instance_info_provider = - chip_device_platform != "linux" && chip_device_platform != "android" && chip_device_platform != "darwin" && chip_device_platform != "webos" && chip_device_platform != "tizen" + chip_device_platform != "linux" && chip_device_platform != "android" && + chip_device_platform != "darwin" && chip_device_platform != "webos" && + chip_device_platform != "tizen" # Enable default/generic test-mode CommissionableDataProvider in GenericConfigurationManagerImpl # === FOR TRANSITION UNTIL ALL EXAMPLES PROVIDE THEIR OWN ===