/*
 *
 *    Copyright (c) 2021 Project CHIP Authors
 *
 *    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 provides implementation of Application Channel class.
 */

#include <messaging/ApplicationExchangeDispatch.h>
#include <protocols/secure_channel/Constants.h>

namespace chip {
namespace Messaging {

CHIP_ERROR ApplicationExchangeDispatch::SendMessageImpl(SecureSessionHandle session, PayloadHeader & payloadHeader,
                                                        System::PacketBufferHandle && message,
                                                        EncryptedPacketBufferHandle * retainedMessage)
{
    return mSessionMgr->SendMessage(session, payloadHeader, std::move(message), retainedMessage);
}

CHIP_ERROR ApplicationExchangeDispatch::ResendMessage(SecureSessionHandle session, EncryptedPacketBufferHandle && message,
                                                      EncryptedPacketBufferHandle * retainedMessage) const
{
    return mSessionMgr->SendEncryptedMessage(session, std::move(message), retainedMessage);
}

bool ApplicationExchangeDispatch::MessagePermitted(uint16_t protocol, uint8_t type)
{
    // TODO: Change this check to only include the protocol and message types that are allowed
    switch (protocol)
    {
    case Protocols::SecureChannel::Id.GetProtocolId():
        switch (type)
        {
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::PBKDFParamRequest):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::PBKDFParamResponse):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::PASE_Spake2p1):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::PASE_Spake2p2):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::PASE_Spake2p3):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::PASE_Spake2pError):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::CASE_SigmaR1):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::CASE_SigmaR2):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::CASE_SigmaR3):
        case static_cast<uint8_t>(Protocols::SecureChannel::MsgType::CASE_SigmaErr):
            return false;

        default:
            break;
        }
        break;

    default:
        break;
    }
    return true;
}

} // namespace Messaging
} // namespace chip
