• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2023 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "softbus_session.h"
17 
18 #include "avsession_log.h"
19 #include "avsession_errors.h"
20 #include "softbus_session_manager.h"
21 #include "softbus_session_utils.h"
22 
23 namespace OHOS::AVSession {
OnConnectSession(int32_t sessionId)24 void SoftbusSession::OnConnectSession(int32_t sessionId)
25 {
26     std::string deviceId;
27     int ret = SoftbusSessionManager::GetInstance().ObtainPeerDeviceId(sessionId, deviceId);
28     CHECK_AND_RETURN_LOG(ret == AVSESSION_SUCCESS, "obtain peer device id failed");
29     std::lock_guard lockGuard(deviceMapLock_);
30     SLOGI("OnConnectSession sessionId:%{public}d|deviceId:%{public}s", sessionId,
31         SoftbusSessionUtils::AnonymizeDeviceId(deviceId).c_str());
32     deviceToSessionMap_.insert({ deviceId, sessionId });
33 }
34 
35 // LCOV_EXCL_START
OnDisConnectSession(int32_t sessionId)36 void SoftbusSession::OnDisConnectSession(int32_t sessionId)
37 {
38     std::string deviceId;
39     int ret = SoftbusSessionManager::GetInstance().ObtainPeerDeviceId(sessionId, deviceId);
40     CHECK_AND_RETURN_LOG(ret == AVSESSION_SUCCESS, "obtain peer device id failed");
41     std::lock_guard lockGuard(deviceMapLock_);
42     SLOGI("OnDisConnectSession sessionId:%{public}d|deviceId:%{public}s", sessionId,
43         SoftbusSessionUtils::AnonymizeDeviceId(deviceId).c_str());
44     deviceToSessionMap_.erase(deviceId);
45 }
46 
SendByteToAll(const std::string & data)47 void SoftbusSession::SendByteToAll(const std::string &data)
48 {
49     SLOGI("SendByteToAllLength: %{public}d", static_cast<int>(data.size()));
50     std::lock_guard lockGuard(deviceMapLock_);
51     for (auto it = deviceToSessionMap_.begin(); it != deviceToSessionMap_.end(); it++) {
52         SLOGI("SendByteToAll : %{public}s", data.c_str());
53         SoftbusSessionManager::GetInstance().SendBytes(it->second, data);
54     }
55 }
56 
SendByte(const std::string & deviceId,const std::string & data)57 void SoftbusSession::SendByte(const std::string &deviceId, const std::string &data)
58 {
59     SLOGI("SendByteLength: %{public}d", static_cast<int>(data.size()));
60     std::lock_guard lockGuard(deviceMapLock_);
61     auto iter = deviceToSessionMap_.find(deviceId);
62     if (iter != deviceToSessionMap_.end()) {
63         SoftbusSessionManager::GetInstance().SendBytes(iter->second, data);
64     }
65 }
66 
SendJsonStringByte(const std::string & deviceId,const std::string & data)67 void SoftbusSession::SendJsonStringByte(const std::string &deviceId, const std::string &data)
68 {
69     SLOGI("SendJsonStringByteLength: %{public}d", static_cast<int>(data.size()));
70     std::lock_guard lockGuard(deviceMapLock_);
71     auto iter = deviceToSessionMap_.find(deviceId);
72     if (iter != deviceToSessionMap_.end()) {
73         SoftbusSessionManager::GetInstance().SendBytesForNext(iter->second, data);
74     } else {
75         SLOGE("SendJsonStringByte findNoDevice:%{public}s", SoftbusSessionUtils::AnonymizeDeviceId(deviceId).c_str());
76     }
77 }
78 
SendByteForNext(const std::string & deviceId,const std::string & data)79 void SoftbusSession::SendByteForNext(const std::string &deviceId, const std::string &data)
80 {
81     std::lock_guard lockGuard(deviceMapLock_);
82     SLOGI("SendByteLength: %{public}d", static_cast<int>(data.size()));
83     auto iter = deviceToSessionMap_.find(deviceId);
84     if (iter != deviceToSessionMap_.end()) {
85         SoftbusSessionManager::GetInstance().SendBytesForNext(iter->second, data);
86     } else {
87         SLOGE("SendByteForNext findNoDevice:%{public}s", SoftbusSessionUtils::AnonymizeDeviceId(deviceId).c_str());
88     }
89 }
90 
SendByte(int32_t sessionId,const std::string & data)91 void SoftbusSession::SendByte(int32_t sessionId, const std::string &data)
92 {
93     SLOGI("SendByteLength: %{public}d", static_cast<int>(data.size()));
94     SoftbusSessionManager::GetInstance().SendBytes(sessionId, data);
95 }
96 
SendByteForNext(int32_t sessionId,const std::string & data)97 void SoftbusSession::SendByteForNext(int32_t sessionId, const std::string &data)
98 {
99     SLOGI("SendByteForNextLength: %{public}d", static_cast<int>(data.size()));
100     int ret = SoftbusSessionManager::GetInstance().SendBytesForNext(sessionId, data);
101     if (ret != AVSESSION_SUCCESS) {
102         SLOGE("SendbyteNext with ret:%{public}d fail!", ret);
103     }
104 }
105 
SendMessage(const std::string & deviceId,const std::string & data)106 void SoftbusSession::SendMessage(const std::string &deviceId, const std::string &data)
107 {
108     SLOGI("SendMessageLength: %{public}d", static_cast<int>(data.size()));
109     std::lock_guard lockGuard(deviceMapLock_);
110     auto iter = deviceToSessionMap_.find(deviceId);
111     if (iter != deviceToSessionMap_.end()) {
112         SoftbusSessionManager::GetInstance().SendMessage(iter->second, data);
113     }
114 }
115 
SendMessage(int32_t sessionId,const std::string & data)116 void SoftbusSession::SendMessage(int32_t sessionId, const std::string &data)
117 {
118     SLOGI("SendMessageLength: %{public}d", static_cast<int>(data.size()));
119     SoftbusSessionManager::GetInstance().SendMessage(sessionId, data);
120 }
121 // LCOV_EXCL_STOP
122 } // namespace OHOS::AVSession