Skip to content

Commit

Permalink
Address review comments
Browse files Browse the repository at this point in the history
  • Loading branch information
nivi-apple committed Nov 17, 2023
1 parent a9e6dc6 commit c84d36c
Show file tree
Hide file tree
Showing 21 changed files with 882 additions and 662 deletions.
44 changes: 22 additions & 22 deletions examples/all-clusters-app/linux/AppOptions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
#include <app/server/CommissioningWindowManager.h>
#include <app/server/Server.h>

using namespace chip;
using namespace chip::ArgParser;
using namespace chip::app::Clusters::DiagnosticLogs;

Expand All @@ -37,9 +38,14 @@ constexpr uint16_t kOptionCrashFilePath = 0xFF05;

static chip::Credentials::Examples::TestHarnessDACProvider mDacProvider;

static char mEndUserSupportLogFileDesignator[kLogFileDesignatorMaxLen];
static char mNetworkDiagnosticsLogFileDesignator[kLogFileDesignatorMaxLen];
static char mCrashLogFileDesignator[kLogFileDesignatorMaxLen];
chip::Optional<std::string> mEndUserSupportLogFilePath;
chip::Optional<std::string> mNetworkDiagnosticsLogFilePath;
chip::Optional<std::string> mCrashLogFilePath;

bool AppOptions::IsNullOrEmpty(const char * value)
{
return (value == nullptr || strlen(value) == 0 || strncmp(value, "", strlen(value)) == 0);
}

bool AppOptions::HandleOptions(const char * program, OptionSet * options, int identifier, const char * name, const char * value)
{
Expand All @@ -54,31 +60,25 @@ bool AppOptions::HandleOptions(const char * program, OptionSet * options, int id
commissionMgr.OverrideMinCommissioningTimeout(chip::System::Clock::Seconds16(static_cast<uint16_t>(atoi(value))));
break;
}
case kOptionEndUserSupportFilePath: {
if (strlen(value) > kLogFileDesignatorMaxLen)
case kOptionEndUserSupportFilePath: {
if (!IsNullOrEmpty(value))
{
PrintArgError("%s: Invalid file path length. Must be less that %d: %d\n", program, kLogFileDesignatorMaxLen,
strlen(value));
mEndUserSupportLogFilePath.SetValue(std::string{value});
}
strncpy(mEndUserSupportLogFileDesignator, value, strlen(value));
break;
}
case kOptionNetworkDiagnosticsFilePath: {
if (strlen(value) > kLogFileDesignatorMaxLen)
if (!IsNullOrEmpty(value))
{
PrintArgError("%s: Invalid file path length. Must be less that %d: %d\n", program, kLogFileDesignatorMaxLen,
strlen(value));
mNetworkDiagnosticsLogFilePath.SetValue(std::string{value});
}
strncpy(mNetworkDiagnosticsLogFileDesignator, value, strlen(value));
break;
}
case kOptionCrashFilePath: {
if (strlen(value) > kLogFileDesignatorMaxLen)
if (!IsNullOrEmpty(value))
{
PrintArgError("%s: Invalid file path length. Must be less that %d: %d\n", program, kLogFileDesignatorMaxLen,
strlen(value));
mCrashLogFilePath.SetValue(std::string{value});
}
strncpy(mCrashLogFileDesignator, value, strlen(value));
break;
}
default:
Expand Down Expand Up @@ -123,17 +123,17 @@ chip::Credentials::DeviceAttestationCredentialsProvider * AppOptions::GetDACProv
return &mDacProvider;
}

char * AppOptions::GetEndUserSupportLogFileDesignator()
Optional<std::string> AppOptions::GetEndUserSupportLogFilePath()
{
return mEndUserSupportLogFileDesignator;
return mEndUserSupportLogFilePath;
}

char * AppOptions::GetNetworkDiagnosticsLogFileDesignator()
Optional<std::string> AppOptions::GetNetworkDiagnosticsLogFilePath()
{
return mNetworkDiagnosticsLogFileDesignator;
return mNetworkDiagnosticsLogFilePath;
}

char * AppOptions::GetCrashLogFileDesignator()
Optional<std::string> AppOptions::GetCrashLogFilePath()
{
return mCrashLogFileDesignator;
return mCrashLogFilePath;
}
10 changes: 6 additions & 4 deletions examples/all-clusters-app/linux/AppOptions.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/*
*
* Copyright (c) 2022 Project CHIP Authors
* Copyright (c) 2022-2023 Project CHIP Authors
* All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
Expand All @@ -27,11 +27,13 @@ class AppOptions
public:
static chip::ArgParser::OptionSet * GetOptions();
static chip::Credentials::DeviceAttestationCredentialsProvider * GetDACProvider();
static char * GetEndUserSupportLogFileDesignator();
static char * GetNetworkDiagnosticsLogFileDesignator();
static char * GetCrashLogFileDesignator();
static chip::Optional<std::string> GetEndUserSupportLogFilePath();
static chip::Optional<std::string> GetNetworkDiagnosticsLogFilePath();
static chip::Optional<std::string> GetCrashLogFilePath();

private:
static bool HandleOptions(const char * program, chip::ArgParser::OptionSet * options, int identifier, const char * name,
const char * value);

static bool IsNullOrEmpty(const char * value);
};
Original file line number Diff line number Diff line change
Expand Up @@ -22,28 +22,42 @@
using namespace chip;
using namespace chip::app::Clusters::DiagnosticLogs;

constexpr uint16_t kChunkSizeZero = 0;

LogProvider LogProvider::sInstance;

LogSessionHandle LogProvider::sLogSessionHandle;

// TODO: Fix #30477 - Add support for multiple log collection sessions

LogSessionHandle LogProvider::StartLogCollection(IntentEnum logType)
{

// We can handle only one log collection session. Return kInvalidLogSessionHandle
// if we are in the middle of another log collection session.
if (mIsInALogCollectionSession)
{
return kInvalidLogSessionHandle;
}

mIsInALogCollectionSession = true;
mTotalNumberOfBytesConsumed = 0;

// Open the file of type
const char * fileName = GetLogFilePath(logType);
if (fileName != nullptr)
// Open the log file for reading.
Optional<std::string> filePath = GetLogFilePath(logType);
if (filePath.HasValue())
{
mFileStream.open(fileName, std::ios_base::binary | std::ios_base::in);
mFileStream.open(filePath.Value().c_str(), std::ios_base::binary | std::ios_base::in);
if (!mFileStream.good())
{
ChipLogError(BDX, "Failed to open the log file");
return kInvalidLogSessionHandle;
}
sLogSessionHandle++;

// If the session handle rolls over to UINT16_MAX which is invalid, reset to 0.
if (sLogSessionHandle == kInvalidLogSessionHandle)
{
sLogSessionHandle = 0;
}
mLogSessionHandle = sLogSessionHandle;
}
else
Expand All @@ -53,79 +67,88 @@ LogSessionHandle LogProvider::StartLogCollection(IntentEnum logType)
return mLogSessionHandle;
}

uint64_t LogProvider::GetNextChunk(LogSessionHandle logSessionHandle, chip::MutableByteSpan & outBuffer, bool & outIsEOF)
CHIP_ERROR LogProvider::GetNextChunk(LogSessionHandle logSessionHandle, MutableByteSpan & outBuffer, bool & outIsEOF)
{
if (logSessionHandle != mLogSessionHandle && outBuffer.size() == 0)
if (!mIsInALogCollectionSession)
{
return kChunkSizeZero;
return CHIP_ERROR_INCORRECT_STATE;
}

if (!mFileStream.is_open())
{
ChipLogError(BDX, "File is not open");
return kChunkSizeZero;
return CHIP_ERROR_INCORRECT_STATE;
}

mFileStream.seekg (mFileStream.end);
long long fileSize = mFileStream.tellg();

long long remainingBytesToBeRead = fileSize - static_cast<long long>(mTotalNumberOfBytesConsumed);

if ((remainingBytesToBeRead >= kMaxLogContentSize && outBuffer.size() < kMaxLogContentSize) || (remainingBytesToBeRead < kMaxLogContentSize && static_cast<long long>(outBuffer.size()) < remainingBytesToBeRead))
{
ChipLogError(BDX, "Buffer is too small to read the next chunk from file");
return CHIP_ERROR_INVALID_ARGUMENT;
}

mFileStream.seekg(static_cast<long long>(mTotalNumberOfBytesConsumed));
mFileStream.read(reinterpret_cast<char *>(outBuffer.data()), kLogContentMaxSize);
mFileStream.read(reinterpret_cast<char *>(outBuffer.data()), kMaxLogContentSize);

if (!(mFileStream.good() || mFileStream.eof()))
{
ChipLogError(BDX, "Failed to read the log file");
mFileStream.close();
return kChunkSizeZero;
return CHIP_ERROR_INCORRECT_STATE;
}

uint64_t bytesRead = static_cast<uint64_t>(mFileStream.gcount());
outBuffer.reduce_size(bytesRead);
outIsEOF = (mFileStream.peek() == EOF);

mTotalNumberOfBytesConsumed += bytesRead;
return bytesRead;
return CHIP_NO_ERROR;
}

void LogProvider::EndLogCollection(LogSessionHandle logSessionHandle)
{
if (logSessionHandle == mLogSessionHandle && mFileStream.is_open())
if (mFileStream.is_open())
{
mFileStream.close();
}
mIsInALogCollectionSession = false;
}

uint64_t LogProvider::GetTotalNumberOfBytesConsumed(LogSessionHandle logSessionHandle)
{
if (logSessionHandle == mLogSessionHandle)
{
return mTotalNumberOfBytesConsumed;
}
return kChunkSizeZero;
return mTotalNumberOfBytesConsumed;
}

const char * LogProvider::GetLogFilePath(IntentEnum logType)
Optional<std::string> LogProvider::GetLogFilePath(IntentEnum logType)
{
switch (logType)
{
case IntentEnum::kEndUserSupport:
return mEndUserSupportLogFileDesignator;
return mEndUserSupportLogFilePath;
case IntentEnum::kNetworkDiag:
return mNetworkDiagnosticsLogFileDesignator;
return mNetworkDiagnosticsLogFilePath;
case IntentEnum::kCrashLogs:
return mCrashLogFileDesignator;
return mCrashLogFilePath;
default:
return nullptr;
return NullOptional;
}
}

void LogProvider::SetEndUserSupportLogFileDesignator(const char * logFileName)
void LogProvider::SetEndUserSupportLogFilePath(Optional<std::string> logFilePath)
{
strncpy(mEndUserSupportLogFileDesignator, logFileName, strlen(logFileName));
mEndUserSupportLogFilePath = logFilePath;
}

void LogProvider::SetNetworkDiagnosticsLogFileDesignator(const char * logFileName)
void LogProvider::SetNetworkDiagnosticsLogFilePath(Optional<std::string> logFilePath)
{
strncpy(mNetworkDiagnosticsLogFileDesignator, logFileName, strlen(logFileName));
mNetworkDiagnosticsLogFilePath = logFilePath;
}

void LogProvider::SetCrashLogFileDesignator(const char * logFileName)
void LogProvider::SetCrashLogFilePath(Optional<std::string> logFilePath)
{
strncpy(mCrashLogFileDesignator, logFileName, strlen(logFileName));
mCrashLogFilePath = logFilePath;
}
Original file line number Diff line number Diff line change
Expand Up @@ -40,34 +40,36 @@ class LogProvider : public LogProviderDelegate
public:
LogSessionHandle StartLogCollection(IntentEnum logType);

uint64_t GetNextChunk(LogSessionHandle logSessionHandle, chip::MutableByteSpan & outBuffer, bool & outIsEOF);
CHIP_ERROR GetNextChunk(LogSessionHandle logSessionHandle, MutableByteSpan & outBuffer, bool & outIsEOF);

void EndLogCollection(LogSessionHandle logSessionHandle);

uint64_t GetTotalNumberOfBytesConsumed(LogSessionHandle logSessionHandle);

void SetEndUserSupportLogFileDesignator(const char * logFileName);
void SetEndUserSupportLogFilePath(Optional<std::string> logFilePath);

void SetNetworkDiagnosticsLogFileDesignator(const char * logFileName);
void SetNetworkDiagnosticsLogFilePath(Optional<std::string> logFilePath);

void SetCrashLogFileDesignator(const char * logFileName);
void SetCrashLogFilePath(Optional<std::string> logFilePath);

LogProvider(){};

~LogProvider(){};

static inline LogProvider & GetInstance() { return sInstance; }
static inline LogProvider & getLogProvider() { return sInstance; }

private:
const char * GetLogFilePath(IntentEnum logType);
Optional<std::string> GetLogFilePath(IntentEnum logType);

char mEndUserSupportLogFileDesignator[kLogFileDesignatorMaxLen];
char mNetworkDiagnosticsLogFileDesignator[kLogFileDesignatorMaxLen];
char mCrashLogFileDesignator[kLogFileDesignatorMaxLen];
Optional<std::string> mEndUserSupportLogFilePath;
Optional<std::string> mNetworkDiagnosticsLogFilePath;
Optional<std::string> mCrashLogFilePath;

std::ifstream mFileStream;

LogSessionHandle mLogSessionHandle;

bool mIsInALogCollectionSession;

uint64_t mTotalNumberOfBytesConsumed;
};
Expand Down
11 changes: 6 additions & 5 deletions examples/all-clusters-app/linux/main-common.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -265,9 +265,10 @@ void emberAfWindowCoveringClusterInitCallback(chip::EndpointId endpoint)
using namespace chip::app::Clusters::DiagnosticLogs;
void emberAfDiagnosticLogsClusterInitCallback(chip::EndpointId endpoint)
{
ChipLogProgress(NotSpecified, "SetDefaultLogProviderDelegate");
DiagnosticLogsServer::Instance().SetDefaultLogProviderDelegate(endpoint, &LogProvider::getLogProvider());
LogProvider::getLogProvider().SetEndUserSupportLogFileDesignator(AppOptions::GetEndUserSupportLogFileDesignator());
LogProvider::getLogProvider().SetNetworkDiagnosticsLogFileDesignator(AppOptions::GetNetworkDiagnosticsLogFileDesignator());
LogProvider::getLogProvider().SetCrashLogFileDesignator(AppOptions::GetCrashLogFileDesignator());
ChipLogProgress(NotSpecified, "SetLogProviderDelegate");
DiagnosticLogsServer::Instance().SetLogProviderDelegate(endpoint, &LogProvider::getLogProvider());

LogProvider::getLogProvider().SetEndUserSupportLogFilePath(AppOptions::GetEndUserSupportLogFilePath());
LogProvider::getLogProvider().SetNetworkDiagnosticsLogFilePath(AppOptions::GetNetworkDiagnosticsLogFilePath());
LogProvider::getLogProvider().SetCrashLogFilePath(AppOptions::GetCrashLogFilePath());
}
Loading

0 comments on commit c84d36c

Please sign in to comment.