/* * * Copyright (c) 2020-2021 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. */ /** * @file * This file contains implementation of Device class. The objects of this * class will be used by Controller applications to interact with CHIP * devices. The class provides mechanism to construct, send and receive * messages to and from the corresponding CHIP devices. */ #include #include #include #include #include #include #include #include using namespace chip::Callback; namespace chip { CHIP_ERROR DeviceProxy::SendCommands(app::CommandSender * commandObj, Optional timeout) { VerifyOrReturnLogError(IsSecureConnected(), CHIP_ERROR_INCORRECT_STATE); VerifyOrReturnError(commandObj != nullptr, CHIP_ERROR_INVALID_ARGUMENT); return commandObj->SendCommandRequest(GetSecureSession().Value(), timeout); } CHIP_ERROR DeviceProxy::GetAttestationChallenge(ByteSpan & attestationChallenge) { Optional secureSessionHandle; secureSessionHandle = GetSecureSession(); VerifyOrReturnError(secureSessionHandle.HasValue(), CHIP_ERROR_INCORRECT_STATE); attestationChallenge = secureSessionHandle.Value()->AsSecureSession()->GetCryptoContext().GetAttestationChallenge(); return CHIP_NO_ERROR; } } // namespace chip