blob: 194142efaaf6e02693bf2cfc115839162133061b [file] [log] [blame]
/*
*
* Copyright (c) 2018 Nest Labs, Inc.
* 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 <Weave/DeviceLayer/internal/WeaveDeviceLayerInternal.h>
#include <Weave/DeviceLayer/internal/DeviceDescriptionServer.h>
using namespace ::nl;
using namespace ::nl::Weave;
using namespace ::nl::Weave::Profiles::DeviceDescription;
namespace nl {
namespace Weave {
namespace DeviceLayer {
namespace Internal {
DeviceDescriptionServer DeviceDescriptionServer::sInstance;
WEAVE_ERROR DeviceDescriptionServer::Init()
{
WEAVE_ERROR err;
// Call init on the server base class.
err = ServerBaseClass::Init(&::nl::Weave::DeviceLayer::ExchangeMgr);
SuccessOrExit(err);
// Set the pointer to the HandleIdentifyRequest function.
OnIdentifyRequestReceived = HandleIdentifyRequest;
exit:
return err;
}
void DeviceDescriptionServer::HandleIdentifyRequest(void *appState, uint64_t nodeId, const IPAddress& nodeAddr,
const IdentifyRequestMessage& reqMsg, bool& sendResp, IdentifyResponseMessage& respMsg)
{
WEAVE_ERROR err = WEAVE_NO_ERROR;
WeaveDeviceDescriptor deviceDesc;
#if WEAVE_PROGRESS_LOGGING
{
char ipAddrStr[64];
nodeAddr.ToString(ipAddrStr, sizeof(ipAddrStr));
WeaveLogProgress(DeviceLayer, "IdentifyRequest received from node %" PRIX64 " (%s)", nodeId, ipAddrStr);
WeaveLogProgress(DeviceLayer, " Target Fabric Id: %016" PRIX64, reqMsg.TargetFabricId);
WeaveLogProgress(DeviceLayer, " Target Modes: %08" PRIX32, reqMsg.TargetModes);
WeaveLogProgress(DeviceLayer, " Target Vendor Id: %04" PRIX16, reqMsg.TargetVendorId);
WeaveLogProgress(DeviceLayer, " Target Product Id: %04" PRIX16, reqMsg.TargetProductId);
}
#endif // WEAVE_PROGRESS_LOGGING
sendResp = true;
if (!MatchTargetFabricId(::nl::Weave::DeviceLayer::FabricState.FabricId, reqMsg.TargetFabricId))
{
WeaveLogProgress(DeviceLayer, "IdentifyRequest target fabric does not match device fabric");
sendResp = false;
}
if (reqMsg.TargetModes != kTargetDeviceMode_Any && (reqMsg.TargetModes & kTargetDeviceMode_UserSelectedMode) == 0)
{
WeaveLogProgress(DeviceLayer, "IdentifyRequest target mode does not match device mode");
sendResp = false;
}
if (reqMsg.TargetVendorId != 0xFFFF)
{
uint16_t vendorId;
err = ConfigurationMgr().GetVendorId(vendorId);
SuccessOrExit(err);
if (reqMsg.TargetVendorId != vendorId)
{
WeaveLogProgress(DeviceLayer, "IdentifyRequest target vendor does not match device vendor");
sendResp = false;
}
}
if (reqMsg.TargetProductId != 0xFFFF)
{
uint16_t productId;
err = ConfigurationMgr().GetProductId(productId);
SuccessOrExit(err);
if (reqMsg.TargetProductId != productId)
{
WeaveLogProgress(DeviceLayer, "IdentifyRequest target product does not match device product");
sendResp = false;
}
}
if (sendResp)
{
WeaveLogProgress(DeviceLayer, "Sending IdentifyResponse");
}
exit:
if (err == WEAVE_NO_ERROR && sendResp)
{
err = ConfigurationMgr().GetDeviceDescriptor(respMsg.DeviceDesc);
}
if (err != WEAVE_NO_ERROR)
{
sendResp = false;
}
}
void DeviceDescriptionServer::OnPlatformEvent(const WeaveDeviceEvent * event)
{
// Nothing to do so far.
}
} // namespace Internal
} // namespace DeviceLayer
} // namespace Weave
} // namespace nl