/* * Copyright (c) 2022 Huawei Device Co., Ltd. * 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 "softbus_session.h" #include "dm_anonymous.h" #include "dm_constants.h" #include "dm_dfx_constants.h" #include "dm_hitrace.h" #include "dm_log.h" #include "nlohmann/json.hpp" #include "softbus_connector.h" namespace OHOS { namespace DistributedHardware { std::shared_ptr SoftbusSession::sessionCallback_ = nullptr; SoftbusSession::SoftbusSession() { } SoftbusSession::~SoftbusSession() { } int32_t SoftbusSession::RegisterSessionCallback(std::shared_ptr callback) { sessionCallback_ = callback; return DM_OK; } int32_t SoftbusSession::UnRegisterSessionCallback() { sessionCallback_ = nullptr; return DM_OK; } int32_t SoftbusSession::OpenAuthSession(const std::string &deviceId) { LOGI("SoftbusSession::OpenAuthSession"); DmTraceStart(std::string(DM_HITRACE_AUTH_TO_OPPEN_SESSION)); int32_t sessionId = -1; std::string connectAddr; ConnectionAddr *addrInfo = SoftbusConnector::GetConnectAddr(deviceId, connectAddr); if (addrInfo == nullptr) { LOGE("GetConnectAddr error"); return sessionId; } sessionId = ::OpenAuthSession(DM_SESSION_NAME, addrInfo, 1, nullptr); if (sessionId < 0) { LOGE("open session error, ret:%d", sessionId); return sessionId; } DmTraceEnd(); LOGI("SoftbusSession::OpenAuthSession success. sessionId is:%d", sessionId); return sessionId; } int32_t SoftbusSession::CloseAuthSession(int32_t sessionId) { LOGI("SoftbusSession::CloseAuthSession"); ::CloseSession(sessionId); return DM_OK; } int32_t SoftbusSession::GetPeerDeviceId(int32_t sessionId, std::string &peerDevId) { char peerDeviceId[DEVICE_UUID_LENGTH] = {0}; int32_t ret = ::GetPeerDeviceId(sessionId, &peerDeviceId[0], DEVICE_UUID_LENGTH); if (ret == 0) { peerDevId = peerDeviceId; LOGI("GetPeerDeviceId success for session:%d, peerDeviceId:%s", sessionId, GetAnonyString(peerDevId).c_str()); return ERR_DM_FAILED; } LOGE("GetPeerDeviceId failed for session:%d", sessionId); peerDevId = ""; return DM_OK; } int32_t SoftbusSession::SendData(int32_t sessionId, std::string &message) { nlohmann::json jsonObject = nlohmann::json::parse(message, nullptr, false); if (jsonObject.is_discarded()) { LOGE("extrasJson error"); return ERR_DM_FAILED; } if (!IsInt32(jsonObject, TAG_MSG_TYPE)) { LOGE("SoftbusSession::SendData err json string."); return ERR_DM_FAILED; } int32_t msgType = jsonObject[TAG_MSG_TYPE].get(); LOGI("AuthMessageProcessor::ParseAuthRequestMessage msgType = %d", msgType); if (sessionCallback_->GetIsCryptoSupport()) { LOGI("SoftbusSession::SendData Start encryption"); } int32_t ret = SendBytes(sessionId, message.c_str(), strlen(message.c_str())); if (ret != DM_OK) { LOGE("SendData Start failed"); return ERR_DM_FAILED; } LOGI("SendData Start success"); return DM_OK; } int SoftbusSession::OnSessionOpened(int sessionId, int result) { int32_t sessionSide = GetSessionSide(sessionId); sessionCallback_->OnSessionOpened(sessionId, sessionSide, result); LOGI("OnSessionOpened, success:"); return DM_OK; } void SoftbusSession::OnSessionClosed(int sessionId) { LOGI("OnSessionClosed, sessionId:%d", sessionId); } void SoftbusSession::OnBytesReceived(int sessionId, const void *data, unsigned int dataLen) { LOGI("OnBytesReceived, sessionId:%d, dataLen:%d", sessionId, dataLen); if (sessionId < 0 || data == nullptr || dataLen <= 0) { LOGI("OnBytesReceived param check failed"); return; } if (sessionCallback_->GetIsCryptoSupport()) { LOGI("SoftbusSession::OnBytesReceived Start decryption"); } std::string message = std::string(reinterpret_cast(data), dataLen); sessionCallback_->OnDataReceived(sessionId, message); LOGI("OnBytesReceived completed"); } } // namespace DistributedHardware } // namespace OHOS