• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2022-2025 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 <sstream>
17 #include <iomanip>
18 #include <iostream>
19 #include <regex>
20 #include <dlfcn.h>
21 #include <thread>
22 #include <chrono>
23 #include <filesystem>
24 #include <openssl/crypto.h>
25 
26 #include "accesstoken_kit.h"
27 #include "account_manager_adapter.h"
28 #include "app_manager_adapter.h"
29 #include "audio_adapter.h"
30 #include "audio_system_manager.h"
31 #include "avsession_dynamic_loader.h"
32 #include "avsession_errors.h"
33 #include "avsession_log.h"
34 #include "avsession_info.h"
35 #include "device_manager.h"
36 #include "remote_session_capability_set.h"
37 #include "remote_session_source_proxy.h"
38 #include "remote_session_sink_proxy.h"
39 #include "file_ex.h"
40 #include "iservice_registry.h"
41 #include "key_event_adapter.h"
42 #include "cJSON.h"
43 #include "permission_checker.h"
44 #include "system_ability_definition.h"
45 #include "session_stack.h"
46 #include "avsession_trace.h"
47 #include "hash_calculator.h"
48 #include "avsession_dumper.h"
49 #include "command_send_limit.h"
50 #include "avsession_sysevent.h"
51 #include "json_utils.h"
52 #include "avsession_utils.h"
53 #include "avcontrol_command.h"
54 #include "avsession_event_handler.h"
55 #include "bundle_status_adapter.h"
56 #include "params_config_operator.h"
57 #include "notification_content.h"
58 #include "notification_helper.h"
59 #include "notification_request.h"
60 #include "notification_constant.h"
61 #include "ability_connect_helper.h"
62 #include "if_system_ability_manager.h"
63 #include "parameter.h"
64 #include "parameters.h"
65 #include "avsession_service.h"
66 #include "want_agent_helper.h"
67 #include "avsession_radar.h"
68 #include "int_wrapper.h"
69 #include "array_wrapper.h"
70 #include "bool_wrapper.h"
71 #include "image_source.h"
72 #include "avsession_pixel_map_adapter.h"
73 #include "avsession_dynamic_insight.h"
74 #include "softbus/softbus_session_utils.h"
75 
76 typedef void (*MigrateStubFunc)(std::function<void(std::string, std::string, std::string, std::string)>);
77 typedef void (*StopMigrateStubFunc)(void);
78 
79 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
80 #include "av_router.h"
81 #include "collaboration_manager.h"
82 #endif
83 
84 #if !defined(WINDOWS_PLATFORM) and !defined(MAC_PLATFORM) and !defined(IOS_PLATFORM)
85 #include <malloc.h>
86 #endif
87 
88 using namespace std;
89 using namespace OHOS::AudioStandard;
90 
91 namespace OHOS::AVSession {
92 
93 static const std::string AVSESSION_DYNAMIC_INSIGHT_LIBRARY_PATH = std::string("libavsession_dynamic_insight.z.so");
94 
95 static const int32_t CAST_ENGINE_SA_ID = 65546;
96 static const int32_t COLLABORATION_SA_ID = 70633;
97 static const int32_t AVSESSION_CONTINUE = 1;
98 #ifndef START_STOP_ON_DEMAND_ENABLE
99 const std::string BOOTEVENT_AVSESSION_SERVICE_READY = "bootevent.avsessionservice.ready";
100 #endif
101 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
102 static const int32_t CONTROL_COLD_START = 2;
103 #endif
104 
105 const std::map<int, int32_t> keyCodeToCommandMap_ = {
106     {MMI::KeyEvent::KEYCODE_MEDIA_PLAY_PAUSE, AVControlCommand::SESSION_CMD_PLAY},
107     {MMI::KeyEvent::KEYCODE_MEDIA_PLAY, AVControlCommand::SESSION_CMD_PLAY},
108     {MMI::KeyEvent::KEYCODE_MEDIA_PAUSE, AVControlCommand::SESSION_CMD_PAUSE},
109     {MMI::KeyEvent::KEYCODE_MEDIA_STOP, AVControlCommand::SESSION_CMD_STOP},
110     {MMI::KeyEvent::KEYCODE_MEDIA_NEXT, AVControlCommand::SESSION_CMD_PLAY_NEXT},
111     {MMI::KeyEvent::KEYCODE_MEDIA_PREVIOUS, AVControlCommand::SESSION_CMD_PLAY_PREVIOUS},
112     {MMI::KeyEvent::KEYCODE_MEDIA_REWIND, AVControlCommand::SESSION_CMD_REWIND},
113     {MMI::KeyEvent::KEYCODE_MEDIA_FAST_FORWARD, AVControlCommand::SESSION_CMD_FAST_FORWARD},
114 };
115 
116 const std::map<int32_t, int32_t> cmdToOffsetMap_ = {
117     {AVControlCommand::SESSION_CMD_SET_TARGET_LOOP_MODE, 9},
118     {AVControlCommand::SESSION_CMD_PLAY, 8},
119     {AVControlCommand::SESSION_CMD_PAUSE, 7},
120     {AVControlCommand::SESSION_CMD_PLAY_NEXT, 6},
121     {AVControlCommand::SESSION_CMD_PLAY_PREVIOUS, 5},
122     {AVControlCommand::SESSION_CMD_FAST_FORWARD, 4},
123     {AVControlCommand::SESSION_CMD_REWIND, 3},
124     {AVControlCommand::SESSION_CMD_SEEK, 2},
125     {AVControlCommand::SESSION_CMD_SET_LOOP_MODE, 1},
126     {AVControlCommand::SESSION_CMD_TOGGLE_FAVORITE, 0}
127 };
128 
129 class NotificationSubscriber : public Notification::NotificationLocalLiveViewSubscriber {
OnConnected()130     void OnConnected() {}
OnDisconnected()131     void OnDisconnected() {}
OnResponse(int32_t notificationId,sptr<Notification::NotificationButtonOption> buttonOption)132     void OnResponse(int32_t notificationId, sptr<Notification::NotificationButtonOption> buttonOption) {}
OnDied()133     void OnDied() {}
134 };
135 
136 static const auto NOTIFICATION_SUBSCRIBER = NotificationSubscriber();
137 
138 #ifndef START_STOP_ON_DEMAND_ENABLE
139 REGISTER_SYSTEM_ABILITY_BY_ID(AVSessionService, AVSESSION_SERVICE_ID, true);
140 #else
141 REGISTER_SYSTEM_ABILITY_BY_ID(AVSessionService, AVSESSION_SERVICE_ID, false);
142 #endif
143 
144 bool g_isCapsuleLive2 = system::GetBoolParameter("persist.systemui.live2", false);
145 std::shared_ptr<Media::PixelMap> g_defaultMediaImage = nullptr;
146 Notification::NotificationRequest g_NotifyRequest;
147 
AVSessionService(int32_t systemAbilityId,bool runOnCreate)148 AVSessionService::AVSessionService(int32_t systemAbilityId, bool runOnCreate)
149     : SystemAbility(systemAbilityId, runOnCreate)
150 {
151 }
152 
~AVSessionService()153 AVSessionService::~AVSessionService()
154 {
155     GetUsersManager().ClearCache();
156 }
157 
OnStart()158 void AVSessionService::OnStart()
159 {
160     SLOGI("OnStart SA with process check");
161     GetUsersManager().ClearCache();
162     CHECK_AND_RETURN_LOG(Publish(this), "publish avsession service failed");
163     OnStartProcess();
164 }
165 
OnStartProcess()166 void AVSessionService::OnStartProcess()
167 {
168     dumpHelper_ = std::make_unique<AVSessionDumper>();
169     CommandSendLimit::GetInstance().StartTimer();
170 
171     ParamsConfigOperator::GetInstance().InitConfig();
172     auto ret = ParamsConfigOperator::GetInstance().GetValueIntByKey("historicalRecordMaxNum", &maxHistoryNums_);
173     if (ret == AVSESSION_ERROR) {
174         maxHistoryNums_ = defMaxHistoryNum;
175     }
176 
177 #ifdef ENABLE_BACKGROUND_AUDIO_CONTROL
178     backgroundAudioController_.Init(this);
179     AddInnerSessionListener(&backgroundAudioController_);
180     for (auto& session : GetContainer().GetAllSessions()) {
181         CHECK_AND_CONTINUE(session != nullptr);
182         SLOGI("backgroundAudioController add sessionCreateBef:%{public}s",
183             AVSessionUtils::GetAnonySessionId(session->GetSessionId()).c_str());
184         backgroundAudioController_.OnSessionCreate(session->GetDescriptor());
185     }
186 #endif
187 
188     AddSystemAbilityListener(MULTIMODAL_INPUT_SERVICE_ID);
189     AddSystemAbilityListener(AUDIO_POLICY_SERVICE_ID);
190     AddSystemAbilityListener(APP_MGR_SERVICE_ID);
191     AddSystemAbilityListener(DISTRIBUTED_HARDWARE_DEVICEMANAGER_SA_ID);
192     AddSystemAbilityListener(BUNDLE_MGR_SERVICE_SYS_ABILITY_ID);
193     AddSystemAbilityListener(CAST_ENGINE_SA_ID);
194     AddSystemAbilityListener(COLLABORATION_SA_ID);
195     AddSystemAbilityListener(MEMORY_MANAGER_SA_ID);
196     AddSystemAbilityListener(SUBSYS_ACCOUNT_SYS_ABILITY_ID_BEGIN);
197     AddSystemAbilityListener(COMMON_EVENT_SERVICE_ID);
198 
199     HISYSEVENT_REGITER;
200     HISYSEVENT_BEHAVIOR("SESSION_SERVICE_START", "SERVICE_NAME", "AVSessionService",
201         "SERVICE_ID", AVSESSION_SERVICE_ID, "DETAILED_MSG", "avsession service start success");
202 #ifndef START_STOP_ON_DEMAND_ENABLE
203     if (!system::GetBoolParameter(BOOTEVENT_AVSESSION_SERVICE_READY.c_str(), false)) {
204         system::SetParameter(BOOTEVENT_AVSESSION_SERVICE_READY.c_str(), "true");
205         SLOGI("set boot avsession service started true");
206     }
207 #endif
208 
209     AVSessionUtils::PublishCommonEvent("usual.event.AVSESSION_START");
210 }
211 
OnDump()212 void AVSessionService::OnDump()
213 {
214 }
215 
OnIdle(const SystemAbilityOnDemandReason & idleReason)216 int32_t AVSessionService::OnIdle(const SystemAbilityOnDemandReason& idleReason)
217 {
218     SLOGI("OnIdle SA, idle reason %{public}d, %{public}s, %{public}s",
219         idleReason.GetId(), idleReason.GetName().c_str(), idleReason.GetValue().c_str());
220     uint32_t ret = GetUsersManager().GetContainerFromAll().GetAllSessions().size();
221     if (ret != 0) {
222         SLOGI("IPC is not used for a long time, there are %{public}d sessions.", ret);
223         return -1;
224     }
225     for (const auto& pair : migrateAVSessionProxyMap_) {
226         std::shared_ptr<MigrateAVSessionProxy> migrateAVSessionProxy =
227             std::static_pointer_cast<MigrateAVSessionProxy>(pair.second);
228         CHECK_AND_CONTINUE(migrateAVSessionProxy != nullptr);
229         CHECK_AND_RETURN_RET_LOG(!migrateAVSessionProxy->CheckMediaAlive(), -1,
230             "migrate proxy with media alive, should not stop");
231     }
232     return 0;
233 }
234 
OnActive(const SystemAbilityOnDemandReason & activeReason)235 void AVSessionService::OnActive(const SystemAbilityOnDemandReason& activeReason)
236 {
237     SLOGI("OnActive SA, idle reason %{public}d, %{public}s, %{public}s",
238         activeReason.GetId(), activeReason.GetName().c_str(), activeReason.GetValue().c_str());
239 }
240 
OnStop()241 void AVSessionService::OnStop()
242 {
243     PublishEvent(remoteMediaNone);
244     StopMigrateStubFunc stopMigrateStub =
245         reinterpret_cast<StopMigrateStubFunc>(dlsym(migrateStubFuncHandle_, "StopMigrateStub"));
246     if (stopMigrateStub == nullptr) {
247         SLOGE("failed to find library, reason: %{public}sn", dlerror());
248     } else {
249         stopMigrateStub();
250     }
251 #ifndef TEST_COVERAGE
252     if (migrateStubFuncHandle_ != nullptr) {
253         OPENSSL_thread_stop();
254     }
255     dlclose(migrateStubFuncHandle_);
256 #endif
257 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
258     CollaborationManager::GetInstance().UnRegisterLifecycleCallback();
259     CollaborationManager::ReleaseInstance();
260 #endif
261     CommandSendLimit::GetInstance().StopTimer();
262     NotifyProcessStatus(false);
263     UnSubscribeCommonEvent();
264     BundleStatusAdapter::ReleaseInstance();
265 }
266 
EventSubscriber(const EventFwk::CommonEventSubscribeInfo & subscriberInfo,AVSessionService * ptr)267 EventSubscriber::EventSubscriber(const EventFwk::CommonEventSubscribeInfo &subscriberInfo, AVSessionService *ptr)
268     : EventFwk::CommonEventSubscriber(subscriberInfo)
269 {
270     servicePtr_ = ptr;
271 }
272 
OnReceiveEvent(const EventFwk::CommonEventData & eventData)273 void EventSubscriber::OnReceiveEvent(const EventFwk::CommonEventData &eventData)
274 {
275     const AAFwk::Want &want = eventData.GetWant();
276     std::string action = want.GetAction();
277     SLOGI("OnReceiveEvent action:%{public}s.", action.c_str());
278     if (servicePtr_ == nullptr) {
279         SLOGE("OnReceiveEvent get action:%{public}s with servicePtr_ null", action.c_str());
280         return;
281     }
282     if (action.compare(EventFwk::CommonEventSupport::COMMON_EVENT_USER_FOREGROUND) == 0) {
283         int32_t userIdForeground = eventData.GetCode();
284         servicePtr_->HandleUserEvent(AVSessionUsersManager::accountEventSwitched, userIdForeground);
285     } else if (action.compare(EventFwk::CommonEventSupport::COMMON_EVENT_USER_SWITCHED) == 0) {
286         int32_t userIdSwitched = eventData.GetCode();
287         servicePtr_->HandleUserEvent(AVSessionUsersManager::accountEventSwitched, userIdSwitched);
288     } else if (action.compare(EventFwk::CommonEventSupport::COMMON_EVENT_USER_REMOVED) == 0) {
289         int32_t userId = eventData.GetCode();
290         servicePtr_->HandleUserEvent(AVSessionUsersManager::accountEventRemoved, userId);
291     } else if (action.compare(EventFwk::CommonEventSupport::COMMON_EVENT_USER_UNLOCKED) == 0) {
292         int32_t userId = eventData.GetCode();
293         servicePtr_->RegisterBundleDeleteEventForHistory(userId);
294     } else if (action.compare(EventFwk::CommonEventSupport::COMMON_EVENT_BOOT_COMPLETED) == 0 ||
295         action.compare(EventFwk::CommonEventSupport::COMMON_EVENT_LOCKED_BOOT_COMPLETED) == 0) {
296         servicePtr_->InitCastEngineService();
297     } else if (action.compare("EVENT_REMOVE_MEDIACONTROLLER_LIVEVIEW") == 0) {
298         servicePtr_->HandleRemoveMediaCardEvent();
299     } else if (action.compare("EVENT_AVSESSION_MEDIA_CAPSULE_STATE_CHANGE") == 0) {
300         std::string param = eventData.GetData();
301         SLOGI("OnReceiveEvent notify data:%{public}s", param.c_str());
302         servicePtr_->HandleMediaCardStateChangeEvent(param);
303     }
304 }
305 
GetAVQueueDir(int32_t userId)306 std::string AVSessionService::GetAVQueueDir(int32_t userId)
307 {
308     return GetUsersManager().GetDirForCurrentUser(userId) + AVQUEUE_FILE_NAME;
309 }
310 
GetAVSortDir(int32_t userId)311 std::string AVSessionService::GetAVSortDir(int32_t userId)
312 {
313     return GetUsersManager().GetDirForCurrentUser(userId) + SORT_FILE_NAME;
314 }
315 
HandleUserEvent(const std::string & type,const int & userId)316 void AVSessionService::HandleUserEvent(const std::string &type, const int &userId)
317 {
318     // del capsule before account switching
319     int32_t curUserId = GetUsersManager().GetCurrentUserId();
320     if (type == AVSessionUsersManager::accountEventSwitched && userId != curUserId && hasMediaCapsule_.load()) {
321         SLOGI("userSwitch userId:%{public}d curUserId:%{public}d hasCapsule:%{public}d",
322             userId, curUserId, hasMediaCapsule_.load());
323         std::lock_guard lockGuard(sessionServiceLock_);
324         NotifySystemUI(nullptr, true, false, false);
325     }
326     GetUsersManager().NotifyAccountsEvent(type, userId);
327     if (type == AVSessionUsersManager::accountEventSwitched) {
328         SLOGD("userSwitch and updateTopSession for userId:%{public}d", userId);
329         UpdateTopSession(GetUsersManager().GetTopSession(), userId);
330     }
331 }
332 
HandleRemoveMediaCardEvent()333 void AVSessionService::HandleRemoveMediaCardEvent()
334 {
335     hasRemoveEvent_ = true;
336     hasMediaCapsule_ = false;
337     std::lock_guard lockGuard(sessionServiceLock_);
338     if (!topSession_) {
339         return;
340     }
341     auto ret = BackgroundTaskMgr::BackgroundTaskMgrHelper::AVSessionNotifyUpdateNotification(
342         topSession_->GetUid(), topSession_->GetPid(), false);
343     if (ret != AVSESSION_SUCCESS) {
344         SLOGE("AVSessionNotifyUpdateNotification failed, uid = %{public}d, pid = %{public}d, ret = %{public}d",
345             topSession_->GetUid(), topSession_->GetPid(), ret);
346     }
347     AVSessionEventHandler::GetInstance().AVSessionRemoveTask("NotifyFlowControl");
348     if (topSession_->IsCasting()) {
349         AVCastControlCommand castCmd;
350         castCmd.SetCommand(AVCastControlCommand::CAST_CONTROL_CMD_PAUSE);
351         topSession_->SendControlCommandToCast(castCmd);
352     } else {
353         AVControlCommand cmd;
354         cmd.SetCommand(AVControlCommand::SESSION_CMD_PAUSE);
355         topSession_->ExecuteControllerCommand(cmd);
356     }
357 }
358 
IsTopSessionPlaying()359 bool AVSessionService::IsTopSessionPlaying()
360 {
361     std::lock_guard lockGuard(sessionServiceLock_);
362     if (!topSession_) {
363         return false;
364     }
365     bool isPlaying = topSession_->IsCasting() ?
366         (topSession_->GetCastAVPlaybackState().GetState() == AVPlaybackState::PLAYBACK_STATE_PLAY) :
367         AudioAdapter::GetInstance().GetRendererRunning(topSession_->GetUid(), topSession_->GetPid());
368     return isPlaying;
369 }
370 
HandleMediaCardStateChangeEvent(std::string isAppear)371 void AVSessionService::HandleMediaCardStateChangeEvent(std::string isAppear)
372 {
373     if (isAppear == "APPEAR") {
374         isMediaCardOpen_ = true;
375         AVSessionEventHandler::GetInstance().AVSessionRemoveTask("CheckCardStateChangeStop");
376         hasCardStateChangeStopTask_ = false;
377     } else if (isAppear == "DISAPPEAR") {
378         isMediaCardOpen_ = false;
379         if (IsTopSessionPlaying() || hasRemoveEvent_.load()) {
380             SLOGI("HandleMediaCardState hasRemoveEvent_:%{public}d ", hasRemoveEvent_.load());
381             return;
382         }
383         hasCardStateChangeStopTask_ = true;
384         AVSessionEventHandler::GetInstance().AVSessionPostTask(
385             [this]() {
386                 if (IsTopSessionPlaying() || hasRemoveEvent_.load() || isMediaCardOpen_.load()) {
387                     SLOGI("HandleMediaCardState hasRemoveEvent_:%{public}d isMediaCardOpen_:%{public}d",
388                         hasRemoveEvent_.load(), isMediaCardOpen_.load());
389                     return;
390                 }
391                 {
392                     std::lock_guard lockGuard(sessionServiceLock_);
393                     NotifySystemUI(nullptr, true, false, false);
394                     hasCardStateChangeStopTask_ = false;
395                 }
396             }, "CheckCardStateChangeStop", cancelTimeout);
397     }
398 }
399 
SubscribeCommonEvent()400 bool AVSessionService::SubscribeCommonEvent()
401 {
402     const std::vector<std::string> events = {
403         EventFwk::CommonEventSupport::COMMON_EVENT_SCREEN_OFF,
404         EventFwk::CommonEventSupport::COMMON_EVENT_SCREEN_ON,
405         EventFwk::CommonEventSupport::COMMON_EVENT_SCREEN_LOCKED,
406         EventFwk::CommonEventSupport::COMMON_EVENT_SCREEN_UNLOCKED,
407         EventFwk::CommonEventSupport::COMMON_EVENT_USER_SWITCHED,
408         EventFwk::CommonEventSupport::COMMON_EVENT_USER_FOREGROUND,
409         EventFwk::CommonEventSupport::COMMON_EVENT_USER_REMOVED,
410         EventFwk::CommonEventSupport::COMMON_EVENT_USER_UNLOCKED,
411         EventFwk::CommonEventSupport::COMMON_EVENT_BOOT_COMPLETED,
412         EventFwk::CommonEventSupport::COMMON_EVENT_LOCKED_BOOT_COMPLETED,
413         "EVENT_REMOVE_MEDIACONTROLLER_LIVEVIEW",
414         "EVENT_AVSESSION_MEDIA_CAPSULE_STATE_CHANGE"
415     };
416 
417     EventFwk::MatchingSkills matchingSkills;
418     for (auto event : events) {
419         matchingSkills.AddEvent(event);
420     }
421     EventFwk::CommonEventSubscribeInfo subscribeInfo(matchingSkills);
422 
423     subscriber_ = std::make_shared<EventSubscriber>(subscribeInfo, this);
424     return EventFwk::CommonEventManager::SubscribeCommonEvent(subscriber_);
425 }
426 
UnSubscribeCommonEvent()427 bool AVSessionService::UnSubscribeCommonEvent()
428 {
429     bool subscribeResult = false;
430     if (subscriber_ != nullptr) {
431         subscribeResult = EventFwk::CommonEventManager::UnSubscribeCommonEvent(subscriber_);
432         subscriber_ = nullptr;
433     }
434     SLOGI("UnSubscribeCommonEvent subscribeResult = %{public}d", subscribeResult);
435 
436     return subscribeResult;
437 }
438 
PullMigrateStub()439 void AVSessionService::PullMigrateStub()
440 {
441     migrateStubFuncHandle_ = dlopen("libavsession_migration.z.so", RTLD_NOW);
442     if (migrateStubFuncHandle_ == nullptr) {
443         SLOGE("failed to dlopen library, reason: %{public}sn", dlerror());
444         return;
445     }
446     MigrateStubFunc startMigrateStub =
447         reinterpret_cast<MigrateStubFunc>(dlsym(migrateStubFuncHandle_, "StartMigrateStub"));
448     if (startMigrateStub == nullptr) {
449         SLOGE("failed to find library, reason: %{public}sn", dlerror());
450         return;
451     }
452     std::thread([startMigrateStub, this]() {
453         SLOGI("create thread to keep MigrateStub");
454         startMigrateStub([this](std::string deviceId, std::string serviceName, std::string extraInfo,
455             std::string state) { SuperLauncher(deviceId, serviceName, extraInfo, state); });
456     }).detach();
457 }
458 
OnAddSystemAbility(int32_t systemAbilityId,const std::string & deviceId)459 void AVSessionService::OnAddSystemAbility(int32_t systemAbilityId, const std::string& deviceId)
460 {
461     SLOGI("Receive SA: %{public}d start callback.", systemAbilityId);
462     switch (systemAbilityId) {
463         case MULTIMODAL_INPUT_SERVICE_ID:
464             InitKeyEvent();
465             break;
466         case AUDIO_POLICY_SERVICE_ID:
467             InitAudio();
468             break;
469         case APP_MGR_SERVICE_ID:
470             InitAMS();
471             break;
472         case DISTRIBUTED_HARDWARE_DEVICEMANAGER_SA_ID:
473             InitDM();
474             break;
475         case BUNDLE_MGR_SERVICE_SYS_ABILITY_ID:
476             InitBMS();
477             InitRadarBMS();
478             break;
479         case CAST_ENGINE_SA_ID:
480 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
481             if (is2in1_) {
482                 checkEnableCast(true);
483             }
484 #endif
485             break;
486         case COLLABORATION_SA_ID:
487             InitCollaboration();
488             PullMigrateStub();
489             break;
490         case MEMORY_MANAGER_SA_ID:
491             NotifyProcessStatus(true);
492             break;
493         case SUBSYS_ACCOUNT_SYS_ABILITY_ID_BEGIN:
494             InitAccountMgr();
495             break;
496         case COMMON_EVENT_SERVICE_ID:
497             InitCommonEventService();
498             break;
499         default:
500             SLOGE("undefined system ability %{public}d", systemAbilityId);
501     }
502 }
503 
OnRemoveSystemAbility(int32_t systemAbilityId,const std::string & deviceId)504 void AVSessionService::OnRemoveSystemAbility(int32_t systemAbilityId, const std::string& deviceId)
505 {
506     SLOGI("remove system ability %{public}d", systemAbilityId);
507 }
508 
NotifyProcessStatus(bool isStart)509 void AVSessionService::NotifyProcessStatus(bool isStart)
510 {
511     int pid = getpid();
512     void *libMemMgrClientHandle = dlopen("libmemmgrclient.z.so", RTLD_NOW);
513     if (!libMemMgrClientHandle) {
514         SLOGE("dlopen libmemmgrclient library failed");
515         return;
516     }
517     void *notifyProcessStatusFunc = dlsym(libMemMgrClientHandle, "notify_process_status");
518     if (!notifyProcessStatusFunc) {
519         SLOGE("dlsm notify_process_status failed");
520 #ifndef TEST_COVERAGE
521         if (libMemMgrClientHandle != nullptr) {
522             OPENSSL_thread_stop();
523         }
524         dlclose(libMemMgrClientHandle);
525 #endif
526         return;
527     }
528     auto notifyProcessStatus = reinterpret_cast<int(*)(int, int, int, int)>(notifyProcessStatusFunc);
529     if (isStart) {
530         SLOGI("notify to memmgr when av_session is started");
531         notifyProcessStatus(pid, saType, 1, AVSESSION_SERVICE_ID); // 1 indicates the service is started
532     } else {
533         SLOGI("notify to memmgr when av_session is stopped");
534         notifyProcessStatus(pid, saType, 0, AVSESSION_SERVICE_ID); // 0 indicates the service is stopped
535     }
536 #ifndef TEST_COVERAGE
537     if (libMemMgrClientHandle != nullptr) {
538         OPENSSL_thread_stop();
539     }
540     dlclose(libMemMgrClientHandle);
541 #endif
542 }
543 
InitKeyEvent()544 void AVSessionService::InitKeyEvent()
545 {
546     SLOGI("enter init keyEvent");
547     std::vector<int32_t> keyCodes = {
548         MMI::KeyEvent::KEYCODE_MEDIA_PLAY,
549         MMI::KeyEvent::KEYCODE_MEDIA_PAUSE,
550         MMI::KeyEvent::KEYCODE_MEDIA_PLAY_PAUSE,
551         MMI::KeyEvent::KEYCODE_MEDIA_STOP,
552         MMI::KeyEvent::KEYCODE_MEDIA_NEXT,
553         MMI::KeyEvent::KEYCODE_MEDIA_PREVIOUS,
554         MMI::KeyEvent::KEYCODE_MEDIA_REWIND,
555         MMI::KeyEvent::KEYCODE_MEDIA_FAST_FORWARD,
556         MMI::KeyEvent::KEYCODE_HEADSETHOOK,
557     };
558 
559     KeyEventAdapter::GetInstance().SubscribeKeyEvent(
560         keyCodes, [this](const auto& keyEvent) { SendSystemAVKeyEvent(*keyEvent); });
561 }
562 
ReportFocusSessionChange(const sptr<AVSessionItem> & topSession,const sptr<AVSessionItem> & newTopSession)563 void ReportFocusSessionChange(const sptr<AVSessionItem>& topSession, const sptr<AVSessionItem>& newTopSession)
564 {
565     HISYSEVENT_BEHAVIOR("FOCUS_CHANGE",
566         "OLD_BUNDLE_NAME", topSession->GetDescriptor().elementName_.GetBundleName(),
567         "OLD_MODULE_NAME", topSession->GetDescriptor().elementName_.GetModuleName(),
568         "OLD_ABILITY_NAME", topSession->GetAbilityName(), "OLD_SESSION_PID", topSession->GetPid(),
569         "OLD_SESSION_UID", topSession->GetUid(), "OLD_SESSION_ID", topSession->GetSessionId(),
570         "OLD_SESSION_TAG", topSession->GetDescriptor().sessionTag_,
571         "OLD_SESSION_TYPE", topSession->GetDescriptor().sessionType_,
572         "BUNDLE_NAME", newTopSession->GetDescriptor().elementName_.GetBundleName(),
573         "MODULE_NAME", newTopSession->GetDescriptor().elementName_.GetModuleName(),
574         "ABILITY_NAME", newTopSession->GetAbilityName(), "SESSION_PID", newTopSession->GetPid(),
575         "SESSION_UID", newTopSession->GetUid(), "SESSION_ID", newTopSession->GetSessionId(),
576         "SESSION_TAG", newTopSession->GetDescriptor().sessionTag_,
577         "SESSION_TYPE", newTopSession->GetDescriptor().sessionType_,
578         "DETAILED_MSG", "avsessionservice handlefocussession, updatetopsession");
579 }
580 
UpdateSessionTimestamp(sptr<AVSessionItem> sessionItem)581 void AVSessionService::UpdateSessionTimestamp(sptr<AVSessionItem> sessionItem)
582 {
583     CHECK_AND_RETURN_LOG(sessionItem != nullptr, "UpdateSessionTimestamp sessionItem is null");
584     auto now = std::chrono::system_clock::now();
585     auto timeSinceEpoch = now.time_since_epoch();
586     auto milliseconds = std::chrono::duration_cast<std::chrono::milliseconds>(timeSinceEpoch).count();
587     sessionItem->SetPlayingTime(milliseconds);
588 }
589 
UpdateTopSession(const sptr<AVSessionItem> & newTopSession,int32_t userId)590 void AVSessionService::UpdateTopSession(const sptr<AVSessionItem>& newTopSession, int32_t userId)
591 {
592     AVSessionDescriptor descriptor;
593     int32_t userIdForNewTopSession = newTopSession != nullptr ? newTopSession->GetUserId() :
594         (userId <= 0 ? GetUsersManager().GetCurrentUserId() : userId);
595     {
596         std::lock_guard lockGuard(sessionServiceLock_);
597         if (newTopSession == nullptr) {
598             if (topSession_ != nullptr && GetUsersManager().GetCurrentUserId() == userIdForNewTopSession) {
599                 topSession_->SetTop(false);
600                 topSession_ = nullptr;
601             }
602             GetUsersManager().SetTopSession(nullptr, userIdForNewTopSession);
603             SLOGI("set topSession to nullptr for userId:%{public}d", userIdForNewTopSession);
604             HISYSEVENT_BEHAVIOR("FOCUS_CHANGE", "DETAILED_MSG", "avsessionservice set topsession to nullptr");
605             return;
606         }
607 
608         SLOGI("updateNewTop uid=%{public}d|pid=%{public}d|userId:%{public}d|sessionId=%{public}s",
609             newTopSession->GetUid(), newTopSession->GetPid(), userIdForNewTopSession,
610             AVSessionUtils::GetAnonySessionId(newTopSession->GetSessionId()).c_str());
611         if (userIdForNewTopSession == GetUsersManager().GetCurrentUserId()) {
612             if (topSession_ != nullptr) {
613                 topSession_->SetTop(false);
614                 ReportFocusSessionChange(topSession_, newTopSession);
615             }
616             topSession_ = newTopSession;
617             // update topsession playingtime
618             UpdateSessionTimestamp(topSession_);
619 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
620             MirrorToStreamCast(topSession_);
621 #endif // CASTPLUS_CAST_ENGINE_ENABLE
622         }
623         GetUsersManager().SetTopSession(newTopSession, userIdForNewTopSession);
624         newTopSession->SetTop(true);
625         descriptor = newTopSession->GetDescriptor();
626     }
627 
628     NotifyTopSessionChanged(descriptor);
629     if (topSession_ != nullptr && !topSession_->IsCasting()) {
630         std::string preloadSessionId = topSession_->GetSessionId();
631         NotifyLocalFrontSessionChangeForMigrate(preloadSessionId);
632     }
633 }
634 
HandleChangeTopSession(int32_t infoUid,int32_t infoPid,int32_t userId)635 void AVSessionService::HandleChangeTopSession(int32_t infoUid, int32_t infoPid, int32_t userId)
636 {
637     std::lock_guard frontLockGuard(sessionFrontLock_);
638     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
639     CHECK_AND_RETURN_LOG(sessionListForFront != nullptr, "sessionListForFront ptr nullptr!");
640     for (const auto& session : *sessionListForFront) {
641         if (session->GetUid() == infoUid && session->GetPid() == infoPid &&
642             (session->GetSessionType() != "voice_call" && session->GetSessionType() != "video_call")) {
643             UpdateTopSession(session);
644             if (topSession_ != nullptr &&
645                 (topSession_->GetSessionType() == "audio" || topSession_->GetSessionType() == "video")) {
646                 AVSessionService::NotifySystemUI(nullptr, true, IsCapsuleNeeded(), false);
647                 PublishEvent(mediaPlayStateTrue);
648                 auto ret = BackgroundTaskMgr::BackgroundTaskMgrHelper::AVSessionNotifyUpdateNotification(
649                     topSession_->GetUid(), topSession_->GetPid(), true);
650                 SLOGD("HandleChangeTopSession Notify Bg, uid = %{public}d, pid = %{public}d, ret = %{public}d",
651                     topSession_->GetUid(), topSession_->GetPid(), ret);
652             }
653             return;
654         }
655     }
656 }
657 
658 // LCOV_EXCL_START
HandleFocusSession(const FocusSessionStrategy::FocusSessionChangeInfo & info,bool isPlaying)659 void AVSessionService::HandleFocusSession(const FocusSessionStrategy::FocusSessionChangeInfo& info, bool isPlaying)
660 {
661     SLOGI("uid=%{public}d, pid=%{public}d curTop:%{public}s",
662         info.uid, info.pid, (topSession_ == nullptr ? "null" : topSession_->GetBundleName()).c_str());
663     std::lock_guard lockGuard(sessionServiceLock_);
664     if (info.uid == ancoUid && isPlaying) {
665         sptr<AVSessionItem> sessionItem = GetContainer().GetSessionByUid(info.uid);
666         CHECK_AND_RETURN_LOG(sessionItem != nullptr, "handle focusession no anco_audio");
667         ancoSession_ = sessionItem;
668         UpdateSessionTimestamp(ancoSession_);
669         return;
670     }
671     int32_t userId = GetUsersManager().GetCurrentUserId();
672     if ((topSession_ && topSession_->GetUid() == info.uid && topSession_->GetPid() == info.pid) &&
673         topSession_->IsCasting()) {
674         SLOGI("cur topSession:%{public}s isCasting", topSession_->GetBundleName().c_str());
675         return;
676     }
677     if (topSession_ && topSession_->GetUid() == info.uid && topSession_->GetPid() == info.pid) {
678         SLOGI(" HandleFocusSession focusSession is current topSession.");
679         auto hasOtherPlayingSession = false;
680         if (topSession_->GetSessionType() == "audio" || topSession_->GetSessionType() == "video") {
681             bool notPublishNotification = !isPlaying &&
682                 (isMediaCardOpen_ || hasRemoveEvent_.load() || hasCardStateChangeStopTask_.load());
683             CHECK_AND_RETURN_LOG(!notPublishNotification,
684                 "isPlaying:%{public}d isCardOpen_:%{public}d hasRemoveEvent_:%{public}d hasRemoveTask_:%{public}d",
685                 isPlaying, isMediaCardOpen_.load(), hasRemoveEvent_.load(), hasCardStateChangeStopTask_.load());
686             if (isPlaying) {
687                 auto ret = BackgroundTaskMgr::BackgroundTaskMgrHelper::AVSessionNotifyUpdateNotification(
688                     topSession_->GetUid(), topSession_->GetPid(), true);
689                 SLOGD("call AVSessionNotifyUpdateNotification, uid = %{public}d, pid = %{public}d, ret = %{public}d",
690                     topSession_->GetUid(), topSession_->GetPid(), ret);
691             } else {
692                 sptr<AVSessionItem> result = GetOtherPlayingSession(userId, "");
693                 hasOtherPlayingSession = (result != nullptr);
694                 HandleOtherSessionPlaying(result);
695             }
696             if (!hasOtherPlayingSession) {
697                 AVSessionService::NotifySystemUI(nullptr, true, isPlaying && IsCapsuleNeeded(), false);
698             }
699 #ifdef START_STOP_ON_DEMAND_ENABLE
700             PublishEvent(mediaPlayStateTrue);
701 #endif
702         }
703         return;
704     }
705     CHECK_AND_RETURN_LOG(isPlaying, "focusSession no play");
706     HandleChangeTopSession(info.uid, info.pid, userId);
707 }
708 // LCOV_EXCL_STOP
709 
710 // LCOV_EXCL_START
InsertSessionItemToCJSON(sptr<AVSessionItem> & session,cJSON * valuesArray)711 bool AVSessionService::InsertSessionItemToCJSON(sptr<AVSessionItem> &session, cJSON* valuesArray)
712 {
713     CHECK_AND_RETURN_RET_LOG(session != nullptr, false, "session get null");
714     CHECK_AND_RETURN_RET_LOG(valuesArray != nullptr, false, "valuesArray get null");
715     cJSON* newValue = cJSON_CreateObject();
716     CHECK_AND_RETURN_RET_LOG(newValue != nullptr, false, "newValue get null");
717     cJSON_AddStringToObject(newValue, "sessionId", session->GetSessionId().c_str());
718     cJSON_AddStringToObject(newValue, "bundleName", session->GetBundleName().c_str());
719     cJSON_AddStringToObject(newValue, "abilityName", session->GetAbilityName().c_str());
720     cJSON_AddStringToObject(newValue, "sessionType", session->GetSessionType().c_str());
721     if (cJSON_GetArraySize(valuesArray) <= 0) {
722         cJSON_AddItemToArray(valuesArray, newValue);
723     } else {
724         cJSON_InsertItemInArray(valuesArray, 0, newValue);
725     }
726     if (cJSON_IsInvalid(valuesArray)) {
727         SLOGE("get newValueArray invalid");
728         return false;
729     }
730     return true;
731 }
732 // LCOV_EXCL_STOP
733 
734 // LCOV_EXCL_START
RefreshFocusSessionSort(sptr<AVSessionItem> & session)735 void AVSessionService::RefreshFocusSessionSort(sptr<AVSessionItem> &session)
736 {
737     std::lock_guard sortFileLockGuard(sessionFileLock_);
738     std::string oldSortContent;
739     if (!LoadStringFromFileEx(GetAVSortDir(), oldSortContent)) {
740         SLOGE("LoadStringFromFileEx failed when refresh focus session sort!");
741         return;
742     }
743     cJSON* valuesArray = cJSON_Parse(oldSortContent.c_str());
744     CHECK_AND_RETURN_LOG(valuesArray != nullptr, "cjson parse nullptr");
745     if (cJSON_IsInvalid(valuesArray) || !cJSON_IsArray(valuesArray)) {
746         SLOGE("parse json invalid");
747         cJSON_Delete(valuesArray);
748         return;
749     }
750     bool sessionExist = false;
751     int arraySize = cJSON_GetArraySize(valuesArray);
752     for (int i = arraySize - 1; i >= 0; i--) {
753         cJSON* itemToDelete = cJSON_GetArrayItem(valuesArray, i);
754         CHECK_AND_CONTINUE(itemToDelete != nullptr && !cJSON_IsInvalid(itemToDelete));
755         cJSON* bundleNameItem = cJSON_GetObjectItem(itemToDelete, "bundleName");
756         cJSON* abilityNameItem = cJSON_GetObjectItem(itemToDelete, "abilityName");
757         if (bundleNameItem == nullptr || cJSON_IsInvalid(bundleNameItem) || !cJSON_IsString(bundleNameItem) ||
758             abilityNameItem == nullptr || cJSON_IsInvalid(abilityNameItem) || !cJSON_IsString(abilityNameItem)) {
759             SLOGI("not contain bundleName or abilityName, pass");
760             continue;
761         }
762         if (strcmp(session->GetBundleName().c_str(), bundleNameItem->valuestring) == 0 &&
763             strcmp(session->GetAbilityName().c_str(), abilityNameItem->valuestring) == 0) {
764             cJSON_DeleteItemFromArray(valuesArray, i);
765             sessionExist = true;
766             break;
767         }
768     }
769     if (sessionExist) {
770         InsertSessionItemToCJSON(session, valuesArray);
771     }
772     std::string newSortContentStr = DoCJSONArrayTransformToString(valuesArray);
773     if (!SaveStringToFileEx(GetAVSortDir(), newSortContentStr)) {
774         SLOGE("SaveStringToFileEx failed when refresh focus session sort!");
775     }
776     cJSON_Delete(valuesArray);
777 }
778 
DoCJSONArrayTransformToString(cJSON * valueItem)779 std::string AVSessionService::DoCJSONArrayTransformToString(cJSON* valueItem)
780 {
781     CHECK_AND_RETURN_RET_LOG(valueItem != nullptr && !cJSON_IsInvalid(valueItem), "", "valueItem invalid");
782     char* newSortContent = cJSON_Print(valueItem);
783     CHECK_AND_RETURN_RET_LOG(newSortContent != nullptr, "", "newValueArray print fail nullptr");
784     std::string newSortContentStr(newSortContent);
785     cJSON_free(newSortContent);
786     return newSortContentStr;
787 }
788 
789 // LCOV_EXCL_STOP
790 
UpdateFrontSession(sptr<AVSessionItem> & sessionItem,bool isAdd)791 void AVSessionService::UpdateFrontSession(sptr<AVSessionItem>& sessionItem, bool isAdd)
792 {
793     CHECK_AND_RETURN_LOG(sessionItem != nullptr, "sessionItem get nullptr!");
794     int32_t userId = sessionItem->GetUserId();
795     SLOGI("UpdateFrontSession with bundle=%{public}s,userId=%{public}d,isAdd=%{public}d",
796         sessionItem->GetBundleName().c_str(), userId, isAdd);
797     std::lock_guard frontLockGuard(sessionFrontLock_);
798     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront(userId);
799     CHECK_AND_RETURN_LOG(sessionListForFront != nullptr, "sessionListForFront ptr nullptr!");
800     auto ret = BackgroundTaskMgr::BackgroundTaskMgrHelper::AVSessionNotifyUpdateNotification(
801         sessionItem->GetUid(), sessionItem->GetPid(), isAdd);
802     if (ret != AVSESSION_SUCCESS) {
803         SLOGE("AVSessionNotifyUpdateNotification failed, uid = %{public}d, pid = %{public}d, ret = %{public}d",
804             sessionItem->GetUid(), sessionItem->GetPid(), ret);
805     }
806     auto it = std::find(sessionListForFront->begin(), sessionListForFront->end(), sessionItem);
807     if (isAdd) {
808         if (it != sessionListForFront->end()) {
809             SLOGI("sessionListForFront has same session bundle=%{public}s", sessionItem->GetBundleName().c_str());
810             return;
811         }
812         sessionListForFront->push_front(sessionItem);
813         if (AudioAdapter::GetInstance().GetRendererRunning(sessionItem->GetUid(), sessionItem->GetPid())) {
814             SLOGI("Renderer Running, RepublishNotification for uid=%{public}d", sessionItem->GetUid());
815             UpdateTopSession(sessionItem);
816             AVSessionDescriptor selectSession = sessionItem->GetDescriptor();
817             NotifySystemUI(&selectSession, true, IsCapsuleNeeded(), false);
818             PublishEvent(mediaPlayStateTrue);
819         }
820     } else {
821         std::lock_guard lockGuard(sessionServiceLock_);
822         HandleTopSessionRelease(userId, sessionItem);
823         sessionListForFront->remove(sessionItem);
824         SLOGI("sessionListForFront with size %{public}d", static_cast<int32_t>(sessionListForFront->size()));
825     }
826     UpdateLocalFrontSession(sessionListForFront);
827 }
828 
UpdateOrder(sptr<AVSessionItem> & sessionItem)829 bool AVSessionService::UpdateOrder(sptr<AVSessionItem>& sessionItem)
830 {
831     CHECK_AND_RETURN_RET_LOG(sessionItem != nullptr, false, "sessionItem is nullptr!");
832     GetContainer().UpdateSessionSort(sessionItem);
833     RefreshFocusSessionSort(sessionItem);
834     std::lock_guard frontLockGuard(sessionFrontLock_);
835     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
836     CHECK_AND_RETURN_RET_LOG(sessionListForFront != nullptr, false, "sessionListForFront ptr nullptr!");
837     auto it = std::find(sessionListForFront->begin(), sessionListForFront->end(), sessionItem);
838     if (it != sessionListForFront->end()) {
839         SLOGI("session is in sessionListForFront_, need to change order of it.");
840         sessionListForFront->remove(sessionItem);
841         sessionListForFront->push_front(sessionItem);
842         UpdateSessionTimestamp(sessionItem);
843     }
844     return true;
845 }
846 
SelectFocusSession(const FocusSessionStrategy::FocusSessionChangeInfo & info)847 bool AVSessionService::SelectFocusSession(const FocusSessionStrategy::FocusSessionChangeInfo& info)
848 {
849     for (auto& session : GetContainer().GetAllSessions()) {
850         if (session->GetDescriptor().sessionTag_ == "RemoteCast" || session->GetPid() != info.pid) {
851             continue;
852         }
853         bool ret = UpdateOrder(session);
854         CHECK_AND_RETURN_RET_LOG(ret, false, "UpdateOrder fail");
855         return true;
856     }
857     return false;
858 }
859 
InitAudio()860 void AVSessionService::InitAudio()
861 {
862     SLOGI("enter");
863     AudioAdapter::GetInstance().Init();
864     focusSessionStrategy_.Init();
865     focusSessionStrategy_.RegisterFocusSessionChangeCallback([this] (const auto& info, bool isPlaying) {
866         HandleFocusSession(info, isPlaying);
867     });
868     focusSessionStrategy_.RegisterFocusSessionSelector([this] (const auto& info) {
869         return SelectFocusSession(info);
870     });
871     queryAllowedPlaybackCallbackFunc_ = GetAllowedPlaybackCallbackFunc();
872     auto ret = AudioAdapter::GetInstance().RegisterAllowedPlaybackCallback(queryAllowedPlaybackCallbackFunc_);
873     if (ret != AVSESSION_SUCCESS) {
874         SLOGE("register query allowed playback callback failed!");
875     }
876 }
877 
SelectSessionByUid(const AudioRendererChangeInfo & info)878 sptr <AVSessionItem> AVSessionService::SelectSessionByUid(const AudioRendererChangeInfo& info)
879 {
880     for (const auto& session : GetContainer().GetAllSessions()) {
881         if (session != nullptr && session->GetUid() == info.clientUID) {
882             return session;
883         }
884     }
885     SLOGI("AudioRendererInfo with uid: %{public}d does not have a corresponding session.", info.clientUID);
886     return nullptr;
887 }
888 
InitAMS()889 void AVSessionService::InitAMS()
890 {
891     SLOGI("enter");
892     AppManagerAdapter::GetInstance().Init();
893     AppManagerAdapter::GetInstance().SetServiceCallbackForAppStateChange([this] (int uid, int state) {
894         SLOGD("uid = %{public}d, state = %{public}d", uid, state);
895         HandleAppStateChange(uid, state);
896     });
897 }
898 
InitDM()899 void AVSessionService::InitDM()
900 {
901     SLOGI("enter");
902     auto callback = std::make_shared<AVSessionInitDMCallback>();
903     CHECK_AND_RETURN_LOG(callback != nullptr, "no memory");
904     int32_t ret = OHOS::DistributedHardware::DeviceManager::GetInstance().InitDeviceManager("av_session", callback);
905     CHECK_AND_RETURN_LOG(ret == 0, "InitDeviceManager error ret is %{public}d", ret);
906     DoTargetDevListenWithDM();
907 }
908 
InitBMS()909 void AVSessionService::InitBMS()
910 {
911     std::lock_guard sortFileLockGuard(sessionFileLock_);
912     SLOGI("enter");
913     BundleStatusAdapter::GetInstance().Init();
914     int userId = GetUsersManager().GetCurrentUserId();
915     if (userId < 0) {
916         SLOGE("InitBMS with userId: %{public}d, not valid, return and wait for InitAccountMgr", userId);
917         return;
918     }
919     RegisterBundleDeleteEventForHistory(userId);
920 }
921 
InitAccountMgr()922 void AVSessionService::InitAccountMgr()
923 {
924     SLOGI("InitAccountMgr in");
925     GetUsersManager().Init();
926     RegisterBundleDeleteEventForHistory();
927 }
928 
InitCommonEventService()929 void AVSessionService::InitCommonEventService()
930 {
931     SLOGI("InitCommonEventService in");
932     bool ret = SubscribeCommonEvent();
933     CHECK_AND_RETURN_LOG(ret, "SubscribeCommonEvent error!");
934 }
935 
InitCollaboration()936 void AVSessionService::InitCollaboration()
937 {
938     SLOGI("InitCollaboration in");
939 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
940     CollaborationManager::GetInstance().ReadCollaborationManagerSo();
941     CollaborationManager::GetInstance().RegisterLifecycleCallback();
942 #endif
943 }
944 
InitCastEngineService()945 void AVSessionService::InitCastEngineService()
946 {
947     SLOGI("InitCastEngineService in");
948 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
949     SLOGI("GetDeviceEnableCast, Prop=%{public}d", static_cast<int>(is2in1_));
950 #endif
951 }
952 
RegisterBundleDeleteEventForHistory(int32_t userId)953 void AVSessionService::RegisterBundleDeleteEventForHistory(int32_t userId)
954 {
955     if (userId <= 0) {
956         userId = GetUsersManager().GetCurrentUserId();
957         SLOGI("do RegisterBundleDeleteEventForHistory with cur userId:%{public}d", userId);
958     } else {
959         SLOGI("do RegisterBundleDeleteEventForHistory with recv userId:%{public}d", userId);
960     }
961 
962     std::string oldSortContent;
963     if (LoadStringFromFileEx(GetAVSortDir(userId), oldSortContent)) {
964         cJSON* valuesArray = cJSON_Parse(oldSortContent.c_str());
965         CHECK_AND_RETURN_LOG(valuesArray != nullptr, "parse json get nullptr");
966         if (cJSON_IsInvalid(valuesArray) || !cJSON_IsArray(valuesArray)) {
967             SLOGE("parse json not valid");
968             cJSON_Delete(valuesArray);
969             return;
970         }
971         auto callback = [this](std::string bundleName, int32_t userId) {
972             SLOGI("recv delete bundle:%{public}s at user:%{public}d", bundleName.c_str(), userId);
973             DeleteAVQueueInfoRecord(bundleName, userId);
974             DeleteHistoricalRecord(bundleName, userId);
975             NotifyHistoricalRecordChange(bundleName, userId);
976         };
977         cJSON* valueItem = nullptr;
978         cJSON_ArrayForEach(valueItem, valuesArray) {
979             CHECK_AND_CONTINUE(valueItem != nullptr && !cJSON_IsInvalid(valueItem));
980             cJSON* bundleNameItem = cJSON_GetObjectItem(valueItem, "bundleName");
981             CHECK_AND_CONTINUE(bundleNameItem != nullptr &&
982                 !cJSON_IsInvalid(bundleNameItem) && cJSON_IsString(bundleNameItem));
983             std::string bundleNameStr(bundleNameItem->valuestring);
984             if (!BundleStatusAdapter::GetInstance().SubscribeBundleStatusEvent(bundleNameStr, callback, userId)) {
985                 SLOGE("SubscribeBundleStatusEvent failed for bundle:%{public}s", bundleNameStr.c_str());
986             }
987         }
988         cJSON_Delete(valuesArray);
989     }
990 }
991 
GetContainer()992 SessionContainer& AVSessionService::GetContainer()
993 {
994     return GetUsersManager().GetContainer();
995 }
996 
GetUsersManager()997 AVSessionUsersManager& AVSessionService::GetUsersManager()
998 {
999     static AVSessionUsersManager usersManager;
1000     return usersManager;
1001 }
1002 
GetCurSessionListForFront(int32_t userId)1003 inline std::shared_ptr<std::list<sptr<AVSessionItem>>> AVSessionService::GetCurSessionListForFront(int32_t userId)
1004 {
1005     return GetUsersManager().GetCurSessionListForFront(userId);
1006 }
1007 
1008 
GetCurKeyEventSessionList(int32_t userId)1009 inline std::shared_ptr<std::list<sptr<AVSessionItem>>> AVSessionService::GetCurKeyEventSessionList(int32_t userId)
1010 {
1011     return GetUsersManager().GetCurSessionListForKeyEvent(userId);
1012 }
1013 
AllocSessionId()1014 std::string AVSessionService::AllocSessionId()
1015 {
1016     auto curNum = sessionSeqNum_++;
1017     std::string id = std::to_string(GetCallingPid()) + "-" + std::to_string(GetCallingUid()) + "-" +
1018                      std::to_string(curNum);
1019 
1020     HashCalculator hashCalculator;
1021     CHECK_AND_RETURN_RET_LOG(hashCalculator.Init() == AVSESSION_SUCCESS, "", "hash init failed");
1022     CHECK_AND_RETURN_RET_LOG(hashCalculator.Update(std::vector<uint8_t>(id.begin(), id.end())) == AVSESSION_SUCCESS,
1023                              "", "hash update failed");
1024     std::vector<uint8_t> hash;
1025     CHECK_AND_RETURN_RET_LOG(hashCalculator.GetResult(hash) == AVSESSION_SUCCESS, "", "hash get result failed");
1026 
1027     std::stringstream stream;
1028     for (const auto byte : hash) {
1029         stream << std::uppercase << std::hex << std::setfill('0') << std::setw(allocSpace) << static_cast<int>(byte);
1030     }
1031     return stream.str();
1032 }
1033 
AbilityHasSession(pid_t pid)1034 bool AVSessionService::AbilityHasSession(pid_t pid)
1035 {
1036     std::lock_guard lockGuard(sessionServiceLock_);
1037     return GetContainer().PidHasSession(pid);
1038 }
1039 
GetPresentController(pid_t pid,const std::string & sessionId)1040 sptr<AVControllerItem> AVSessionService::GetPresentController(pid_t pid, const std::string& sessionId)
1041 {
1042     std::lock_guard lockGuard(sessionServiceLock_);
1043     auto it = controllers_.find(pid);
1044     if (it != controllers_.end()) {
1045         for (const auto& controller: it->second) {
1046             if (controller != nullptr && controller->HasSession(sessionId)) {
1047                 return controller;
1048             }
1049         }
1050     }
1051     SLOGI("Not found controller for pid:%{public}d, sessionId:%{public}s.", pid,
1052         AVSessionUtils::GetAnonySessionId(sessionId).c_str());
1053     return nullptr;
1054 }
1055 
NotifySessionCreate(const AVSessionDescriptor & descriptor)1056 void AVSessionService::NotifySessionCreate(const AVSessionDescriptor& descriptor)
1057 {
1058     std::lock_guard lockGuard(sessionListenersLock_);
1059     auto audioSystemManager = AudioStandard::AudioSystemManager::GetInstance();
1060     if (audioSystemManager != nullptr) {
1061         auto ret = audioSystemManager->NotifySessionStateChange(descriptor.uid_, descriptor.pid_, true);
1062         if (ret != AVSESSION_SUCCESS) {
1063             SLOGE("NotifySessionStateChange failed, uid = %{public}d, pid = %{public}d, ret = %{public}d",
1064                 descriptor.uid_, descriptor.pid_, ret);
1065         }
1066     } else {
1067         SLOGE("AudioSystemManager is nullptr");
1068     }
1069     std::map<pid_t, sptr<ISessionListener>> listenerMap = GetUsersManager().GetSessionListener();
1070 #ifdef START_STOP_ON_DEMAND_ENABLE
1071         PublishEvent(mediaPlayStateTrue);
1072 #endif
1073     for (const auto& [pid, listener] : listenerMap) {
1074         AVSESSION_TRACE_SYNC_START("AVSessionService::OnSessionCreate");
1075         if (listener != nullptr) {
1076             listener->OnSessionCreate(descriptor);
1077         }
1078     }
1079     std::map<pid_t, sptr<ISessionListener>> listenerMapForAll = GetUsersManager().GetSessionListenerForAllUsers();
1080     for (const auto& [pid, listener] : listenerMapForAll) {
1081         AVSESSION_TRACE_SYNC_START("AVSessionService::OnSessionCreate");
1082         if (listener != nullptr) {
1083             listener->OnSessionCreate(descriptor);
1084         }
1085     }
1086 
1087     {
1088         std::lock_guard lockGuard(migrateListenersLock_);
1089         for (const auto& listener : innerSessionListeners_) {
1090             if (listener != nullptr) {
1091                 listener->OnSessionCreate(descriptor);
1092             }
1093         }
1094     }
1095 }
1096 
NotifySessionRelease(const AVSessionDescriptor & descriptor)1097 void AVSessionService::NotifySessionRelease(const AVSessionDescriptor& descriptor)
1098 {
1099     std::lock_guard lockGuard(sessionListenersLock_);
1100     auto audioSystemManager = AudioStandard::AudioSystemManager::GetInstance();
1101     if (audioSystemManager != nullptr) {
1102         auto ret = audioSystemManager->NotifySessionStateChange(descriptor.uid_, descriptor.pid_, false);
1103         if (ret != AVSESSION_SUCCESS) {
1104             SLOGE("NotifySessionStateChange failed, uid = %{public}d, pid = %{public}d, ret = %{public}d",
1105                 descriptor.uid_, descriptor.pid_, ret);
1106         }
1107     } else {
1108         SLOGE("AudioSystemManager is nullptr");
1109     }
1110     auto ret = BackgroundTaskMgr::BackgroundTaskMgrHelper::AVSessionNotifyUpdateNotification(
1111         descriptor.uid_, descriptor.pid_, false);
1112     if (ret != AVSESSION_SUCCESS) {
1113         SLOGE("AVSessionNotifyUpdateNotification failed, uid = %{public}d, pid = %{public}d, ret = %{public}d",
1114             descriptor.uid_, descriptor.pid_, ret);
1115     }
1116     std::map<pid_t, sptr<ISessionListener>> listenerMap = GetUsersManager().GetSessionListener(descriptor.userId_);
1117     SLOGI("NotifySessionRelease for user:%{public}d|listenerSize:%{public}d",
1118         descriptor.userId_, static_cast<int>(listenerMap.size()));
1119     for (const auto& [pid, listener] : listenerMap) {
1120         if (listener != nullptr) {
1121             listener->OnSessionRelease(descriptor);
1122         }
1123     }
1124     std::map<pid_t, sptr<ISessionListener>> listenerMapForAll = GetUsersManager().GetSessionListenerForAllUsers();
1125     for (const auto& [pid, listener] : listenerMapForAll) {
1126         if (listener != nullptr) {
1127             listener->OnSessionRelease(descriptor);
1128         }
1129     }
1130 
1131     {
1132         std::lock_guard lockGuard(migrateListenersLock_);
1133         for (const auto& listener : innerSessionListeners_) {
1134             if (listener != nullptr) {
1135                 listener->OnSessionRelease(descriptor);
1136             }
1137         }
1138     }
1139 }
1140 
NotifyTopSessionChanged(const AVSessionDescriptor & descriptor)1141 void AVSessionService::NotifyTopSessionChanged(const AVSessionDescriptor& descriptor)
1142 {
1143     std::lock_guard lockGuard(sessionListenersLock_);
1144     std::map<pid_t, sptr<ISessionListener>> listenerMap = GetUsersManager().GetSessionListener();
1145     for (const auto& [pid, listener] : listenerMap) {
1146         AVSESSION_TRACE_SYNC_START("AVSessionService::OnTopSessionChange");
1147         if (listener != nullptr) {
1148             listener->OnTopSessionChange(descriptor);
1149         }
1150     }
1151     std::map<pid_t, sptr<ISessionListener>> listenerMapForAll = GetUsersManager().GetSessionListenerForAllUsers();
1152     for (const auto& [pid, listener] : listenerMapForAll) {
1153         AVSESSION_TRACE_SYNC_START("AVSessionService::OnTopSessionChange");
1154         if (listener != nullptr) {
1155             listener->OnTopSessionChange(descriptor);
1156         }
1157     }
1158 
1159     {
1160         std::lock_guard lockGuard(migrateListenersLock_);
1161         for (const auto& listener : innerSessionListeners_) {
1162             if (listener != nullptr) {
1163                 listener->OnTopSessionChange(descriptor);
1164             }
1165         }
1166     }
1167 }
1168 
LowQualityCheck(int32_t uid,int32_t pid,AudioStandard::StreamUsage streamUsage,AudioStandard::RendererState rendererState)1169 void AVSessionService::LowQualityCheck(int32_t uid, int32_t pid, AudioStandard::StreamUsage streamUsage,
1170     AudioStandard::RendererState rendererState)
1171 {
1172     sptr<AVSessionItem> session = GetContainer().GetSessionByUid(uid);
1173     CHECK_AND_RETURN_LOG(session != nullptr, "session not exist for LowQualityCheck");
1174 
1175     AVMetaData meta = session->GetMetaDataWithoutImg();
1176     bool hasTitle = !meta.GetTitle().empty();
1177     bool hasImage = meta.GetMediaImage() != nullptr || !meta.GetMediaImageUri().empty();
1178     if ((hasTitle || hasImage) && (session->GetSupportCommand().size() != 0)) {
1179         SLOGD("LowQualityCheck pass for %{public}s, return", session->GetBundleName().c_str());
1180         return;
1181     }
1182     int32_t commandQuality = 0;
1183     for (auto cmd : session->GetSupportCommand()) {
1184         auto it = cmdToOffsetMap_.find(cmd);
1185         if (it != cmdToOffsetMap_.end()) {
1186             commandQuality += (1 << it->second);
1187         }
1188     }
1189     SLOGD("LowQualityCheck report for %{public}s", session->GetBundleName().c_str());
1190     AVSessionSysEvent::BackControlReportInfo reportInfo;
1191     reportInfo.bundleName_ = session->GetBundleName();
1192     reportInfo.streamUsage_ = streamUsage;
1193     reportInfo.isBack_ = AppManagerAdapter::GetInstance().IsAppBackground(uid, pid);
1194     reportInfo.playDuration_ = -1;
1195     reportInfo.isAudioActive_ = true;
1196     reportInfo.metaDataQuality_ = (hasTitle << 1) + hasImage;
1197     reportInfo.cmdQuality_ = commandQuality;
1198     reportInfo.playbackState_ = session->GetPlaybackState().GetState();
1199     AVSessionSysEvent::GetInstance().AddLowQualityInfo(reportInfo);
1200 }
1201 
PlayStateCheck(int32_t uid,AudioStandard::StreamUsage streamUsage,AudioStandard::RendererState rState)1202 void AVSessionService::PlayStateCheck(int32_t uid, AudioStandard::StreamUsage streamUsage,
1203     AudioStandard::RendererState rState)
1204 {
1205     sptr<AVSessionItem> session = GetContainer().GetSessionByUid(uid);
1206     CHECK_AND_RETURN_LOG(session != nullptr, "session not exist for LowQualityCheck");
1207 
1208     AVPlaybackState aState = session->GetPlaybackState();
1209     if ((rState == AudioStandard::RENDERER_RUNNING && aState.GetState() != AVPlaybackState::PLAYBACK_STATE_PLAY) ||
1210         ((rState == AudioStandard::RENDERER_PAUSED || rState == AudioStandard::RENDERER_STOPPED) &&
1211         aState.GetState() == AVPlaybackState::PLAYBACK_STATE_PLAY)) {
1212         SLOGD("PlayStateCheck report for %{public}s", session->GetBundleName().c_str());
1213         HISYSEVENT_FAULT("AVSESSION_WRONG_STATE",
1214             "BUNDLE_NAME", session->GetBundleName(),
1215             "RENDERER_STATE", rState,
1216             "AVSESSION_STATE", aState.GetState());
1217     }
1218 }
1219 
NotifyBackgroundReportCheck(const int32_t uid,const int32_t pid,AudioStandard::StreamUsage streamUsage,AudioStandard::RendererState rendererState)1220 void AVSessionService::NotifyBackgroundReportCheck(const int32_t uid, const int32_t pid,
1221     AudioStandard::StreamUsage streamUsage, AudioStandard::RendererState rendererState)
1222 {
1223     // low quality check
1224     if (rendererState == AudioStandard::RENDERER_RUNNING) {
1225         AVSessionEventHandler::GetInstance().AVSessionPostTask(
1226             [this, uid, pid, streamUsage, rendererState]() {
1227                 LowQualityCheck(uid, pid, streamUsage, rendererState);
1228             }, "LowQualityCheck", lowQualityTimeout);
1229     }
1230 
1231     // error renderer state check
1232     AVSessionEventHandler::GetInstance().AVSessionPostTask(
1233         [this, uid, streamUsage, rendererState]() {
1234             PlayStateCheck(uid, streamUsage, rendererState);
1235         }, "PlayStateCheck", errorStateTimeout);
1236 }
1237 
1238 // LCOV_EXCL_START
NotifyAudioSessionCheck(const int32_t uid)1239 void AVSessionService::NotifyAudioSessionCheck(const int32_t uid)
1240 {
1241     std::lock_guard lockGuard(sessionListenersLock_);
1242     std::map<pid_t, sptr<ISessionListener>> listenerMap = GetUsersManager().GetSessionListener();
1243     for (const auto& [pid, listener] : listenerMap) {
1244         AVSESSION_TRACE_SYNC_START("AVSessionService::OnAudioSessionCheck");
1245         if (listener != nullptr) {
1246             listener->OnAudioSessionChecked(uid);
1247         }
1248     }
1249     std::map<pid_t, sptr<ISessionListener>> listenerMapForAll = GetUsersManager().GetSessionListenerForAllUsers();
1250     for (const auto& [pid, listener] : listenerMapForAll) {
1251         AVSESSION_TRACE_SYNC_START("AVSessionService::OnAudioSessionCheck");
1252         if (listener != nullptr) {
1253             listener->OnAudioSessionChecked(uid);
1254         }
1255     }
1256     {
1257         std::lock_guard lockGuard(migrateListenersLock_);
1258         for (const auto& listener : innerSessionListeners_) {
1259             if (listener != nullptr) {
1260                 listener->OnAudioSessionChecked(uid);
1261             }
1262         }
1263     }
1264 }
1265 // LCOV_EXCL_STOP
1266 
CheckAncoAudio()1267 bool AVSessionService::CheckAncoAudio()
1268 {
1269     for (const auto& session : GetContainer().GetAllSessions()) {
1270         if (session->GetBundleName() == "anco_audio") {
1271             return true;
1272         }
1273     }
1274     return false;
1275 }
1276 
1277 // LCOV_EXCL_START
HandleCallStartEvent()1278 void AVSessionService::HandleCallStartEvent()
1279 {
1280     SLOGI("Call mediaController player in sink side when cast state is connected.");
1281     AbilityConnectHelper::GetInstance().StartAbilityForegroundByCall(MEDIA_CONTROL_BUNDLENAME,
1282         MEDIA_CONTROL_ABILITYNAME);
1283 }
1284 // LCOV_EXCL_STOP
1285 
AddCapsuleServiceCallback(sptr<AVSessionItem> & sessionItem)1286 void AVSessionService::AddCapsuleServiceCallback(sptr<AVSessionItem>& sessionItem)
1287 {
1288     sessionItem->SetServiceCallbackForNtfCapsule([this](std::string sessionId, bool isMediaChange) {
1289         std::lock_guard lockGuard(sessionServiceLock_);
1290         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1291         if (session && topSession_ && (topSession_.GetRefPtr() == session.GetRefPtr())) {
1292             SLOGI("MediaCapsule topsession %{public}s updateImage", topSession_->GetBundleName().c_str());
1293             NotifySystemUI(nullptr, true, IsCapsuleNeeded() && hasMediaCapsule_.load(), isMediaChange);
1294         }
1295     });
1296 
1297     sessionItem->SetServiceCallbackForMediaSession([this](std::string sessionId, bool isPlaying, bool isMediaChange) {
1298         // only use for anco mediasession
1299         std::lock_guard lockGuard(sessionServiceLock_);
1300         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1301         CHECK_AND_RETURN_LOG(session != nullptr, "session not exist");
1302         bool isSameTop = topSession_ != nullptr && (topSession_.GetRefPtr() == session.GetRefPtr());
1303         if (isSameTop) {
1304             SLOGI("ancoCapsule topSession is %{public}s isPlaying %{public}d isMediaChange %{public}d",
1305                 topSession_->GetBundleName().c_str(), isPlaying, isMediaChange);
1306             if (!isPlaying && (isMediaCardOpen_.load() || hasRemoveEvent_.load())) {
1307                 SLOGI("ancoCapsule del isCardOpen_:%{public}d hasRemoveEvent_:%{public}d",
1308                     isMediaCardOpen_.load(), hasRemoveEvent_.load());
1309                 return;
1310             }
1311             auto hasOtherSessionPlaying = false;
1312             if (!isPlaying) {
1313                 int32_t userId = topSession_->GetUserId();
1314                 userId = userId < 0 ? GetUsersManager().GetCurrentUserId() : userId;
1315                 sptr<AVSessionItem> result = GetOtherPlayingSession(userId, "");
1316                 hasOtherSessionPlaying = result != nullptr;
1317                 HandleOtherSessionPlaying(result);
1318             }
1319             if (!hasOtherSessionPlaying) {
1320                 NotifySystemUI(nullptr, true, isPlaying && IsCapsuleNeeded(), isMediaChange);
1321             }
1322             return;
1323         }
1324         CHECK_AND_RETURN_LOG(isPlaying, "anco media session is not playing");
1325         UpdateTopSession(session);
1326         FocusSessionStrategy::FocusSessionChangeInfo sessionInfo;
1327         sessionInfo.uid = session->GetUid();
1328         sessionInfo.pid = session->GetPid();
1329         SelectFocusSession(sessionInfo);
1330         NotifySystemUI(nullptr, true, isPlaying && IsCapsuleNeeded(), isMediaChange);
1331     });
1332 }
1333 
AddCastCapsuleServiceCallback(sptr<AVSessionItem> & sessionItem)1334 void AVSessionService::AddCastCapsuleServiceCallback(sptr<AVSessionItem>& sessionItem)
1335 {
1336 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
1337     sessionItem->SetServiceCallbackForCastNtfCapsule([this](std::string sessionId, bool isPlaying, bool isChange) {
1338         std::lock_guard lockGuard(sessionServiceLock_);
1339         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1340         CHECK_AND_RETURN_LOG(session != nullptr, "castSession not exist");
1341         if (topSession_ && (topSession_.GetRefPtr() == session.GetRefPtr())) {
1342             SLOGI("MediaCapsule topSession is castSession %{public}s isPlaying %{public}d isMediaChange %{public}d",
1343                 topSession_->GetBundleName().c_str(), isPlaying, isChange);
1344             if (!isPlaying && (isMediaCardOpen_ || hasRemoveEvent_.load())) {
1345                 SLOGI("MediaCapsule casttopsession not playing isCardOpen_:%{public}d hasRemoveEvent_:%{public}d",
1346                     isMediaCardOpen_.load(), hasRemoveEvent_.load());
1347                 return;
1348             }
1349             auto hasOtherSessionPlaying = false;
1350             if (!isPlaying) {
1351                 int32_t userId = topSession_->GetUserId();
1352                 userId = userId < 0 ? GetUsersManager().GetCurrentUserId() : userId;
1353                 sptr<AVSessionItem> result = GetOtherPlayingSession(userId, "");
1354                 hasOtherSessionPlaying = result != nullptr;
1355                 HandleOtherSessionPlaying(result);
1356             }
1357             if (!hasOtherSessionPlaying) {
1358                 NotifySystemUI(nullptr, true, isPlaying && IsCapsuleNeeded(), isChange);
1359             }
1360             return;
1361         }
1362         bool castChange = topSession_ && topSession_->IsCasting() && (topSession_.GetRefPtr() != session.GetRefPtr());
1363         if ((topSession_ == nullptr || castChange) && isPlaying) {
1364             SLOGI("MediaCapsule fresh castSession %{public}s to top, isMediaChange %{public}d",
1365                 session->GetBundleName().c_str(), isChange);
1366             UpdateTopSession(session);
1367             NotifySystemUI(nullptr, true, isPlaying, isChange);
1368             bool updateOrderResult = UpdateOrder(session);
1369             CHECK_AND_RETURN_LOG(updateOrderResult, "UpdateOrder fail");
1370         }
1371     });
1372 #endif // CASTPLUS_CAST_ENGINE_ENABLE
1373 }
1374 
AddKeyEventServiceCallback(sptr<AVSessionItem> & sessionItem)1375 void AVSessionService::AddKeyEventServiceCallback(sptr<AVSessionItem>& sessionItem)
1376 {
1377     sessionItem->SetServiceCallbackForKeyEvent([this](std::string sessionId) {
1378         int32_t err = PermissionChecker::GetInstance().CheckPermission(
1379             PermissionChecker::CHECK_MEDIA_RESOURCES_PERMISSION);
1380         CHECK_AND_RETURN_LOG(err == AVSESSION_SUCCESS, "Add KeyEventSession, CheckPermission failed!");
1381         std::lock_guard lockGuard(sessionServiceLock_);
1382         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1383         CHECK_AND_RETURN_LOG(session != nullptr, "session not exist for KeyEvent");
1384         {
1385             std::lock_guard lockGuard(keyEventListLock_);
1386             int userId = session->GetUserId();
1387             std::shared_ptr<std::list<sptr<AVSessionItem>>> keyEventList = GetCurKeyEventSessionList(userId);
1388             CHECK_AND_RETURN_LOG(keyEventList != nullptr, "keyEventList ptr nullptr!");
1389             auto it = std::find(keyEventList->begin(), keyEventList->end(), session);
1390             if (it == keyEventList->end()) {
1391                 SLOGI("keyEventList add=%{public}s", session->GetBundleName().c_str());
1392                 keyEventList->push_front(session);
1393                 return;
1394             }
1395         }
1396     });
1397 }
1398 
ServiceCallback(sptr<AVSessionItem> & sessionItem)1399 void AVSessionService::ServiceCallback(sptr<AVSessionItem>& sessionItem)
1400 {
1401     if (sessionItem == nullptr) {
1402         SLOGE("sessionItem is null when serviceCallback");
1403         return;
1404     }
1405     sessionItem->SetServiceCallbackForRelease([this](AVSessionItem& session) {
1406         HandleSessionRelease(session.GetDescriptor().sessionId_, true);
1407     });
1408     sessionItem->SetServiceCallbackForAVQueueInfo([this](AVSessionItem& session) {
1409         AddAvQueueInfoToFile(session);
1410     });
1411     sessionItem->SetServiceCallbackForCallStart([this](AVSessionItem& session) {
1412         HandleCallStartEvent();
1413     });
1414     sessionItem->SetServiceCallbackForUpdateSession([this](std::string sessionId, bool isAdd) {
1415         if (sessionId == sessionCastState_) {
1416             std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
1417             UpdateLocalFrontSession(sessionListForFront);
1418             return;
1419         }
1420         std::lock_guard lockGuard(sessionServiceLock_);
1421         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1422         CHECK_AND_RETURN_LOG(session != nullptr, "session not exist for UpdateFrontSession");
1423         UpdateFrontSession(session, isAdd);
1424     });
1425     sessionItem->SetServiceCallbackForUpdateExtras([this](std::string sessionId) {
1426         std::lock_guard lockGuard(sessionServiceLock_);
1427         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1428         CHECK_AND_RETURN_LOG(session != nullptr, "session not exist for UpdateFrontSession");
1429         if (topSession_ && topSession_.GetRefPtr() == session.GetRefPtr()) {
1430             AVSessionDescriptor selectSession = session->GetDescriptor();
1431             NotifySystemUI(&selectSession, true, IsCapsuleNeeded() && hasMediaCapsule_.load(), false);
1432         }
1433     });
1434     AddCapsuleServiceCallback(sessionItem);
1435     AddCastCapsuleServiceCallback(sessionItem);
1436     AddKeyEventServiceCallback(sessionItem);
1437 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
1438     sessionItem->SetServiceCallbackForStream([this](std::string sessionId) {
1439         sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1440         CHECK_AND_RETURN_LOG(session != nullptr, "Session not exist");
1441         MirrorToStreamCast(session);
1442     });
1443 #endif // CASTPLUS_CAST_ENGINE_ENABLE
1444 }
1445 
GetIntValueFromJson(const std::string & extraInfo,const char * key)1446 static int32_t GetIntValueFromJson(const std::string& extraInfo, const char* key)
1447 {
1448     auto defaultValue = 0;
1449     cJSON* jsonData = nullptr;
1450     if (!SoftbusSessionUtils::TransferStrToJson(extraInfo, jsonData)) {
1451         SLOGE("json parse fail");
1452         return defaultValue;
1453     }
1454     int32_t value = SoftbusSessionUtils::GetIntFromJson(jsonData, key);
1455     cJSON_Delete(jsonData);
1456     return value;
1457 }
1458 
CreateNewSessionWithExtra(const std::string & tag,int32_t type,const std::string & extraInfo,bool thirdPartyApp,const AppExecFwk::ElementName & elementName)1459 sptr<AVSessionItem> AVSessionService::CreateNewSessionWithExtra(const std::string& tag, int32_t type,
1460                                                                 const std::string& extraInfo, bool thirdPartyApp,
1461                                                                 const AppExecFwk::ElementName& elementName)
1462 {
1463     SLOGI("%{public}s %{public}d %{public}s %{public}s thirdPartyApp=%{public}d", tag.c_str(), type,
1464           elementName.GetBundleName().c_str(), elementName.GetAbilityName().c_str(), thirdPartyApp);
1465     AVSessionDescriptor descriptor;
1466     descriptor.sessionId_ = AllocSessionId();
1467     if (descriptor.sessionId_.empty()) {
1468         SLOGE("alloc session id failed");
1469         return nullptr;
1470     }
1471     descriptor.userId_ = GetUsersManager().GetCurrentUserId();
1472     descriptor.sessionTag_ = tag;
1473     descriptor.sessionType_ = type;
1474     descriptor.elementName_ = elementName;
1475     descriptor.isThirdPartyApp_ = thirdPartyApp;
1476     descriptor.index_ = GetIntValueFromJson(extraInfo, "index");
1477 
1478     sptr<AVSessionItem> result = new(std::nothrow) AVSessionItem(descriptor, descriptor.userId_);
1479     if (result == nullptr) {
1480         return nullptr;
1481     }
1482     result->SetPid(GetCallingPid());
1483     result->SetUid(GetCallingUid());
1484     ServiceCallback(result);
1485 
1486     OutputDeviceInfo outputDeviceInfo;
1487     DeviceInfo deviceInfo;
1488     deviceInfo.castCategory_ = AVCastCategory::CATEGORY_LOCAL;
1489     deviceInfo.deviceId_ = "0";
1490     deviceInfo.deviceName_ = "LocalDevice";
1491     outputDeviceInfo.deviceInfos_.emplace_back(deviceInfo);
1492     result->SetOutputDevice(outputDeviceInfo);
1493 
1494     return result;
1495 }
1496 
CreateNewSession(const std::string & tag,int32_t type,bool thirdPartyApp,const AppExecFwk::ElementName & elementName)1497 sptr<AVSessionItem> AVSessionService::CreateNewSession(const std::string& tag, int32_t type, bool thirdPartyApp,
1498                                                        const AppExecFwk::ElementName& elementName)
1499 {
1500     SLOGI("%{public}s %{public}d %{public}s %{public}s thirdPartyApp=%{public}d", tag.c_str(), type,
1501           elementName.GetBundleName().c_str(), elementName.GetAbilityName().c_str(), thirdPartyApp);
1502     AVSessionDescriptor descriptor;
1503     descriptor.sessionId_ = AllocSessionId();
1504     if (descriptor.sessionId_.empty()) {
1505         SLOGE("alloc session id failed");
1506         return nullptr;
1507     }
1508     descriptor.userId_ = GetUsersManager().GetCurrentUserId();
1509     descriptor.sessionTag_ = tag;
1510     descriptor.sessionType_ = type;
1511     descriptor.elementName_ = elementName;
1512     descriptor.isThirdPartyApp_ = thirdPartyApp;
1513 
1514     sptr<AVSessionItem> result = new(std::nothrow) AVSessionItem(descriptor, descriptor.userId_);
1515     if (result == nullptr) {
1516         return nullptr;
1517     }
1518     result->SetPid(GetCallingPid());
1519     result->SetUid(GetCallingUid());
1520     ServiceCallback(result);
1521 
1522     OutputDeviceInfo outputDeviceInfo;
1523     DeviceInfo deviceInfo;
1524     deviceInfo.castCategory_ = AVCastCategory::CATEGORY_LOCAL;
1525     deviceInfo.deviceId_ = "0";
1526     deviceInfo.deviceName_ = "LocalDevice";
1527     outputDeviceInfo.deviceInfos_.emplace_back(deviceInfo);
1528     result->SetOutputDevice(outputDeviceInfo);
1529 
1530     return result;
1531 }
1532 
IsParamInvalid(const std::string & tag,int32_t type,const AppExecFwk::ElementName & elementName)1533 bool AVSessionService::IsParamInvalid(const std::string& tag, int32_t type, const AppExecFwk::ElementName& elementName)
1534 {
1535     if (tag.empty()) {
1536         SLOGE("tag is empty when create session");
1537         return false;
1538     }
1539     if (type != AVSession::SESSION_TYPE_AUDIO && type != AVSession::SESSION_TYPE_VIDEO
1540         && type != AVSession::SESSION_TYPE_VOICE_CALL && type != AVSession::SESSION_TYPE_VIDEO_CALL) {
1541         SLOGE("type is invalid when create session");
1542         return false;
1543     }
1544     if (elementName.GetBundleName().empty() || elementName.GetAbilityName().empty()) {
1545         SLOGE("element is invalid when create session");
1546         return false;
1547     }
1548     if (GetCallingUid() == audioBrokerUid && tag == "ancoMediaSession") {
1549         return true;
1550     }
1551     std::regex nameRegex("[A-Za-z\\w\\.]*");
1552     if (!std::regex_match(elementName.GetBundleName(), nameRegex)) {
1553         SLOGE("err regex when create session, bundleName=%{public}s", (elementName.GetBundleName()).c_str());
1554         return false;
1555     }
1556     if (!std::regex_match(elementName.GetAbilityName(), nameRegex)) {
1557         SLOGE("err regex when create session, abilityName=%{public}s", (elementName.GetAbilityName()).c_str());
1558         return false;
1559     }
1560 
1561     return true;
1562 }
1563 
CheckAndUpdateAncoMediaSession(const AppExecFwk::ElementName & elementName)1564 void AVSessionService::CheckAndUpdateAncoMediaSession(const AppExecFwk::ElementName& elementName)
1565 {
1566     auto uid = GetCallingUid();
1567     CHECK_AND_RETURN_LOG(uid == audioBrokerUid, "not broker uid");
1568     sptr<AVSessionItem> session = GetContainer().GetSessionByUid(uid);
1569     CHECK_AND_RETURN_LOG(session != nullptr, "anco media session is null");
1570     auto res = GetUsersManager().UpdateSessionForCurrentUser(session->GetPid(), session->GetAbilityName(),
1571         elementName.GetAbilityName(), session);
1572     CHECK_AND_RETURN_LOG(res == AVSESSION_SUCCESS, "update media session fail");
1573     session->UpdateSessionElement(elementName);
1574     SLOGI("updatenewsession %{public}s %{public}s", elementName.GetBundleName().c_str(),
1575         elementName.GetAbilityName().c_str());
1576 }
1577 
CreateSessionInner(const std::string & tag,int32_t type,bool thirdPartyApp,const AppExecFwk::ElementName & elementName,sptr<AVSessionItem> & sessionItem)1578 int32_t AVSessionService::CreateSessionInner(const std::string& tag, int32_t type, bool thirdPartyApp,
1579                                              const AppExecFwk::ElementName& elementName,
1580                                              sptr<AVSessionItem>& sessionItem)
1581 {
1582     if (!IsParamInvalid(tag, type, elementName)) {
1583         return ERR_INVALID_PARAM;
1584     }
1585     auto pid = GetCallingPid();
1586     std::lock_guard lockGuard(sessionServiceLock_);
1587     if (AbilityHasSession(pid)) {
1588         SLOGE("process %{public}d %{public}s already has one session", pid, elementName.GetAbilityName().c_str());
1589         CheckAndUpdateAncoMediaSession(elementName);
1590         return ERR_SESSION_IS_EXIST;
1591     }
1592 
1593     sptr<AVSessionItem> result = CreateNewSession(tag, type, thirdPartyApp, elementName);
1594     if (result == nullptr) {
1595         SLOGE("create new session failed");
1596         if (dumpHelper_ != nullptr) {
1597             dumpHelper_->SetErrorInfo("  AVSessionService::CreateSessionInner  create new session failed");
1598         }
1599         HISYSEVENT_FAULT("CONTROL_COMMAND_FAILED", "CALLER_PID", pid, "TAG", tag, "TYPE", type, "BUNDLE_NAME",
1600             elementName.GetBundleName(), "ERROR_MSG", "avsessionservice createsessioninner create new session failed");
1601         return ERR_NO_MEMORY;
1602     }
1603     if (GetUsersManager().AddSessionForCurrentUser(pid, elementName.GetAbilityName(), result) != AVSESSION_SUCCESS) {
1604         SLOGE("session num exceed max");
1605         return ERR_SESSION_EXCEED_MAX;
1606     }
1607 
1608     HISYSEVENT_ADD_LIFE_CYCLE_INFO(elementName.GetBundleName(),
1609         AppManagerAdapter::GetInstance().IsAppBackground(GetCallingUid(), GetCallingPid()), type, true);
1610 
1611     NotifySessionCreate(result->GetDescriptor());
1612     sessionItem = result;
1613 
1614     std::lock_guard frontLockGuard(sessionFrontLock_);
1615     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
1616     CHECK_AND_RETURN_RET_LOG(sessionListForFront != nullptr, AVSESSION_ERROR, "sessionListForFront ptr nullptr!");
1617     auto it = std::find(sessionListForFront->begin(), sessionListForFront->end(), sessionItem);
1618     if ((type == AVSession::SESSION_TYPE_VOICE_CALL || type == AVSession::SESSION_TYPE_VIDEO_CALL) &&
1619         it == sessionListForFront->end()) {
1620         SLOGI(" front session add voice_call session=%{public}s", sessionItem->GetBundleName().c_str());
1621         sessionListForFront->push_front(sessionItem);
1622     }
1623 
1624 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
1625         ReportSessionState(sessionItem, SessionState::STATE_CREATE);
1626 #endif
1627 
1628     return AVSESSION_SUCCESS;
1629 }
1630 
CreateSessionInnerWithExtra(const std::string & tag,int32_t type,const std::string & extra,bool thirdPartyApp,const AppExecFwk::ElementName & elementName,sptr<AVSessionItem> & sessionItem)1631 int32_t AVSessionService::CreateSessionInnerWithExtra(const std::string& tag, int32_t type, const std::string& extra,
1632                                                       bool thirdPartyApp, const AppExecFwk::ElementName& elementName,
1633                                                       sptr<AVSessionItem>& sessionItem)
1634 {
1635     if (!IsParamInvalid(tag, type, elementName)) {
1636         return ERR_INVALID_PARAM;
1637     }
1638     auto pid = GetCallingPid();
1639     std::lock_guard lockGuard(sessionServiceLock_);
1640     if (AbilityHasSession(pid)) {
1641         SLOGE("process %{public}d %{public}s already has one session", pid, elementName.GetAbilityName().c_str());
1642         CheckAndUpdateAncoMediaSession(elementName);
1643         return ERR_SESSION_IS_EXIST;
1644     }
1645 
1646     sptr<AVSessionItem> result = CreateNewSession(tag, type, thirdPartyApp, elementName);
1647     if (result == nullptr) {
1648         SLOGE("create new session failed");
1649         if (dumpHelper_ != nullptr) {
1650             dumpHelper_->SetErrorInfo("AVSessionService::CreateSessionInner  create new session failed");
1651         }
1652         HISYSEVENT_FAULT("CONTROL_COMMAND_FAILED", "CALLER_PID", pid, "TAG", tag, "TYPE", type, "BUNDLE_NAME",
1653             elementName.GetBundleName(), "ERROR_MSG", "avsessionservice createsessioninner create new session failed");
1654         return ERR_NO_MEMORY;
1655     }
1656     if (GetUsersManager().AddSessionForCurrentUser(pid, elementName.GetAbilityName(), result) != AVSESSION_SUCCESS) {
1657         SLOGE("session num exceed max");
1658         return ERR_SESSION_EXCEED_MAX;
1659     }
1660 
1661     HISYSEVENT_ADD_LIFE_CYCLE_INFO(elementName.GetBundleName(),
1662         AppManagerAdapter::GetInstance().IsAppBackground(GetCallingUid(), GetCallingPid()), type, true);
1663 
1664     NotifySessionCreate(result->GetDescriptor());
1665     sessionItem = result;
1666 
1667     std::lock_guard frontLockGuard(sessionFrontLock_);
1668     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
1669     CHECK_AND_RETURN_RET_LOG(sessionListForFront != nullptr, AVSESSION_ERROR, "sessionListForFront ptr nullptr!");
1670     auto it = std::find(sessionListForFront->begin(), sessionListForFront->end(), sessionItem);
1671     if ((type == AVSession::SESSION_TYPE_VOICE_CALL || type == AVSession::SESSION_TYPE_VIDEO_CALL) &&
1672         it == sessionListForFront->end()) {
1673         SLOGI(" front session add voice_call session=%{public}s", sessionItem->GetBundleName().c_str());
1674         sessionListForFront->push_front(sessionItem);
1675     }
1676 
1677 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
1678         ReportSessionState(sessionItem, SessionState::STATE_CREATE);
1679 #endif
1680 
1681     return AVSESSION_SUCCESS;
1682 }
1683 
CreateSessionInner(const std::string & tag,int32_t type,bool thirdPartyApp,const AppExecFwk::ElementName & elementName)1684 sptr<AVSessionItem> AVSessionService::CreateSessionInner(const std::string& tag, int32_t type, bool thirdPartyApp,
1685                                                          const AppExecFwk::ElementName& elementName)
1686 {
1687     sptr<AVSessionItem> sessionItem;
1688     auto res = CreateSessionInner(tag, type, thirdPartyApp, elementName, sessionItem);
1689     CHECK_AND_RETURN_RET_LOG(res == AVSESSION_SUCCESS, nullptr, "create avSessionItem failed");
1690     return sessionItem;
1691 }
1692 
ReportSessionInfo(const sptr<AVSessionItem> & session,int32_t res)1693 void AVSessionService::ReportSessionInfo(const sptr <AVSessionItem>& session, int32_t res)
1694 {
1695     std::string sessionId = "";
1696     std::string sessionTag = "";
1697     std::string sessionType = "";
1698     std::string bundleName = "";
1699     std::string apiParamString = "";
1700     if (session != nullptr) {
1701         sessionId = AVSessionUtils::GetAnonySessionId(session->GetDescriptor().sessionId_);
1702         sessionTag = session->GetDescriptor().sessionTag_;
1703         sessionType = session->GetSessionType();
1704         bundleName = session->GetDescriptor().elementName_.GetBundleName();
1705         apiParamString = "abilityName: " +
1706             session->GetDescriptor().elementName_.GetAbilityName() + ","
1707             + "moduleName: " + session->GetDescriptor().elementName_.GetModuleName();
1708     }
1709     std::string errMsg = (res == AVSESSION_SUCCESS) ? "SUCCESS" : "create session failed";
1710     HISYSEVENT_BEHAVIOR("SESSION_API_BEHAVIOR",
1711         "API_NAME", "CreateSession",
1712         "BUNDLE_NAME", bundleName,
1713         "SESSION_ID",  sessionId,
1714         "SESSION_TAG", sessionTag,
1715         "SESSION_TYPE", sessionType,
1716         "API_PARAM", apiParamString,
1717         "ERROR_CODE", res,
1718         "ERROR_MSG", errMsg);
1719 }
1720 
CreateSessionInner(const std::string & tag,int32_t type,const AppExecFwk::ElementName & elementName,sptr<IRemoteObject> & object)1721 int32_t AVSessionService::CreateSessionInner(const std::string& tag, int32_t type,
1722                                              const AppExecFwk::ElementName& elementName,
1723                                              sptr<IRemoteObject>& object)
1724 {
1725     sptr<AVSessionItem> session;
1726     auto res = CreateSessionInner(tag, type,
1727         PermissionChecker::GetInstance().CheckPermission(PermissionChecker::CHECK_SYSTEM_PERMISSION),
1728         elementName, session);
1729     CHECK_AND_RETURN_RET_LOG(res == AVSESSION_SUCCESS, res, "create session fail");
1730 
1731     std::string supportModule;
1732     std::string profile;
1733     if (BundleStatusAdapter::GetInstance().IsSupportPlayIntent(elementName.GetBundleName(), supportModule, profile)) {
1734         SLOGI("bundleName=%{public}s support play intent, refreshSortFile", elementName.GetBundleName().c_str());
1735         SaveSessionInfoInFile(session->GetSessionId(), session->GetSessionType(), elementName);
1736     }
1737 
1738     {
1739         std::lock_guard lockGuard1(abilityManagerLock_);
1740         std::string bundleName = session->GetDescriptor().elementName_.GetBundleName();
1741         std::string abilityName = session->GetDescriptor().elementName_.GetAbilityName();
1742         auto it = abilityManager_.find(bundleName + abilityName);
1743         if (it != abilityManager_.end() && it->second != nullptr) {
1744             it->second->StartAbilityByCallDone(session->GetDescriptor().sessionId_);
1745         }
1746     }
1747 
1748     object = session;
1749     ReportSessionInfo(session, static_cast<int32_t>(res));
1750 
1751     {
1752         std::lock_guard lockGuard(isAllSessionCastLock_);
1753         CHECK_AND_RETURN_RET_LOG(isAllSessionCast_, AVSESSION_SUCCESS, "no need to cast");
1754     }
1755     CHECK_AND_RETURN_RET_LOG(CastAudioForNewSession(session) == AVSESSION_SUCCESS,
1756                              AVSESSION_SUCCESS, "cast new session error");
1757     return res;
1758 }
1759 
CreateSessionInnerWithExtra(const std::string & tag,int32_t type,const std::string & extraInfo,const AppExecFwk::ElementName & elementName,sptr<IRemoteObject> & object)1760 int32_t AVSessionService::CreateSessionInnerWithExtra(const std::string& tag, int32_t type,
1761                                                       const std::string& extraInfo,
1762                                                       const AppExecFwk::ElementName& elementName,
1763                                                       sptr<IRemoteObject>& object)
1764 {
1765     sptr<AVSessionItem> session;
1766     auto res = CreateSessionInnerWithExtra(tag, type, extraInfo,
1767         PermissionChecker::GetInstance().CheckPermission(PermissionChecker::CHECK_SYSTEM_PERMISSION),
1768         elementName, session);
1769     CHECK_AND_RETURN_RET_LOG(res == AVSESSION_SUCCESS, res, "create session fail");
1770 
1771     std::string supportModule;
1772     std::string profile;
1773     if (BundleStatusAdapter::GetInstance().IsSupportPlayIntent(elementName.GetBundleName(), supportModule, profile)) {
1774         SaveSessionInfoInFile(session->GetSessionId(), session->GetSessionType(), elementName);
1775     }
1776 
1777     {
1778         std::lock_guard lockGuard1(abilityManagerLock_);
1779         std::string bundleName = session->GetDescriptor().elementName_.GetBundleName();
1780         std::string abilityName = session->GetDescriptor().elementName_.GetAbilityName();
1781         auto it = abilityManager_.find(bundleName + abilityName);
1782         if (it != abilityManager_.end() && it->second != nullptr) {
1783             it->second->StartAbilityByCallDone(session->GetDescriptor().sessionId_);
1784         }
1785     }
1786 
1787     object = session;
1788     ReportSessionInfo(session, static_cast<int32_t>(res));
1789 
1790     {
1791         std::lock_guard lockGuard(isAllSessionCastLock_);
1792         CHECK_AND_RETURN_RET_LOG(isAllSessionCast_, AVSESSION_SUCCESS, "no need to cast");
1793     }
1794     CHECK_AND_RETURN_RET_LOG(CastAudioForNewSession(session) == AVSESSION_SUCCESS,
1795                              AVSESSION_SUCCESS, "cast new session error");
1796     return res;
1797 }
1798 
CreateSessionInner(const std::string & tag,int32_t type,const AppExecFwk::ElementName & elementName)1799 sptr <IRemoteObject> AVSessionService::CreateSessionInner(const std::string& tag, int32_t type,
1800                                                           const AppExecFwk::ElementName& elementName)
1801 {
1802     sptr<IRemoteObject> object;
1803     auto res = CreateSessionInner(tag, type, elementName, object);
1804     CHECK_AND_RETURN_RET_LOG(res == AVSESSION_SUCCESS, nullptr, "create session fail");
1805     return object;
1806 }
1807 
IsCapsuleNeeded()1808 bool AVSessionService::IsCapsuleNeeded()
1809 {
1810     CHECK_AND_RETURN_RET_LOG(topSession_ != nullptr && topSession_->GetUid() != audioBrokerUid,
1811         false, "audio broker capsule");
1812     return topSession_->GetSessionType() == "audio" || topSession_->IsCasting();
1813 }
1814 
1815 // LCOV_EXCL_START
InsertSessionItemToCJSONAndPrint(const std::string & sessionId,const std::string & sessionType,const AppExecFwk::ElementName & elementName,cJSON * valuesArray)1816 bool AVSessionService::InsertSessionItemToCJSONAndPrint(const std::string& sessionId, const std::string& sessionType,
1817     const AppExecFwk::ElementName& elementName, cJSON* valuesArray)
1818 {
1819     CHECK_AND_RETURN_RET_LOG(valuesArray != nullptr, false, "valuesArray get null");
1820     cJSON* newValue = cJSON_CreateObject();
1821     CHECK_AND_RETURN_RET_LOG(newValue != nullptr, false, "newValue get null");
1822     cJSON_AddStringToObject(newValue, "sessionId", sessionId.c_str());
1823     cJSON_AddStringToObject(newValue, "bundleName", elementName.GetBundleName().c_str());
1824     cJSON_AddStringToObject(newValue, "abilityName", elementName.GetAbilityName().c_str());
1825     cJSON_AddStringToObject(newValue, "sessionType", sessionType.c_str());
1826 
1827     if (cJSON_GetArraySize(valuesArray) <= 0) {
1828         cJSON_AddItemToArray(valuesArray, newValue);
1829     } else {
1830         cJSON_InsertItemInArray(valuesArray, 0, newValue);
1831     }
1832     if (cJSON_IsInvalid(valuesArray)) {
1833         SLOGE("get newValueArray invalid");
1834         return false;
1835     }
1836     std::string newSortContentStr = DoCJSONArrayTransformToString(valuesArray);
1837     if (!SaveStringToFileEx(GetAVSortDir(), newSortContentStr)) {
1838         SLOGE("SaveStringToFileEx failed when refresh focus session sort!");
1839     }
1840     return true;
1841 }
1842 // LCOV_EXCL_STOP
1843 
1844 // LCOV_EXCL_START
SaveSessionInfoInFile(const std::string & sessionId,const std::string & sessionType,const AppExecFwk::ElementName & elementName)1845 void AVSessionService::SaveSessionInfoInFile(const std::string& sessionId, const std::string& sessionType,
1846                                              const AppExecFwk::ElementName& elementName)
1847 {
1848     std::lock_guard sortFileLockGuard(sessionFileLock_);
1849     SLOGI("refresh sort when session created, bundleName=%{public}s", (elementName.GetBundleName()).c_str());
1850     std::string oldSortContent;
1851 
1852     if (LoadStringFromFileEx(GetAVSortDir(), oldSortContent)) {
1853         cJSON* valuesArray = cJSON_Parse(oldSortContent.c_str());
1854         CHECK_AND_RETURN_LOG(valuesArray != nullptr, "parse json get nullptr");
1855         if (cJSON_IsInvalid(valuesArray) || !cJSON_IsArray(valuesArray)) {
1856             SLOGE("parse json not valid");
1857             cJSON_Delete(valuesArray);
1858             valuesArray = cJSON_CreateArray();
1859             CHECK_AND_RETURN_LOG(valuesArray != nullptr, "create array json fail");
1860         }
1861         if (oldSortContent.find(elementName.GetBundleName()) == string::npos) {
1862             auto callback = [this](std::string bundleName, int32_t userId) {
1863                 SLOGI("recv delete bundle:%{public}s at user:%{public}d", bundleName.c_str(), userId);
1864                 DeleteAVQueueInfoRecord(bundleName, userId);
1865                 DeleteHistoricalRecord(bundleName, userId);
1866                 NotifyHistoricalRecordChange(bundleName, userId);
1867             };
1868             if (!BundleStatusAdapter::GetInstance().SubscribeBundleStatusEvent(elementName.GetBundleName(),
1869                 callback, GetUsersManager().GetCurrentUserId())) {
1870                 SLOGE("SubscribeBundleStatusEvent failed");
1871             }
1872         }
1873         int arraySize = cJSON_GetArraySize(valuesArray);
1874         for (int i = arraySize - 1; i >= 0; i--) {
1875             cJSON* itemToDelete = cJSON_GetArrayItem(valuesArray, i);
1876             CHECK_AND_CONTINUE(itemToDelete != nullptr && !cJSON_IsInvalid(itemToDelete));
1877             cJSON* bundleNameItem = cJSON_GetObjectItem(itemToDelete, "bundleName");
1878             cJSON* abilityNameItem = cJSON_GetObjectItem(itemToDelete, "abilityName");
1879             if (bundleNameItem == nullptr || cJSON_IsInvalid(bundleNameItem) || !cJSON_IsString(bundleNameItem) ||
1880                 abilityNameItem == nullptr || cJSON_IsInvalid(abilityNameItem) || !cJSON_IsString(abilityNameItem)) {
1881                 SLOGI("not contain bundleName or abilityName, pass");
1882                 continue;
1883             }
1884             if (strcmp(elementName.GetBundleName().c_str(), bundleNameItem->valuestring) == 0 &&
1885                 strcmp(elementName.GetAbilityName().c_str(), abilityNameItem->valuestring) == 0) {
1886                 cJSON_DeleteItemFromArray(valuesArray, i);
1887             }
1888         }
1889         InsertSessionItemToCJSONAndPrint(sessionId, sessionType, elementName, valuesArray);
1890         cJSON_Delete(valuesArray);
1891     } else {
1892         SLOGE("LoadStringToFile failed, filename=%{public}s", SORT_FILE_NAME);
1893     }
1894 }
1895 // LCOV_EXCL_STOP
1896 
GetAllSessionDescriptors(std::vector<AVSessionDescriptor> & descriptors)1897 int32_t AVSessionService::GetAllSessionDescriptors(std::vector<AVSessionDescriptor>& descriptors)
1898 {
1899     std::lock_guard frontLockGuard(sessionFrontLock_);
1900     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
1901     CHECK_AND_RETURN_RET_LOG(sessionListForFront != nullptr, AVSESSION_ERROR, "sessionListForFront ptr nullptr!");
1902     for (const auto& session : *sessionListForFront) {
1903         if (session != nullptr) {
1904             descriptors.push_back(session->GetDescriptor());
1905         }
1906     }
1907     SLOGI("GetAllSessionDescriptors with size=%{public}d, topSession:%{public}s",
1908         static_cast<int32_t>(descriptors.size()),
1909         (topSession_ == nullptr ? "null" : topSession_->GetBundleName()).c_str());
1910     return AVSESSION_SUCCESS;
1911 }
1912 
GetSessionDescriptorsBySessionId(const std::string & sessionId,AVSessionDescriptor & descriptor)1913 int32_t AVSessionService::GetSessionDescriptorsBySessionId(const std::string& sessionId,
1914                                                            AVSessionDescriptor& descriptor)
1915 {
1916     std::lock_guard lockGuard(sessionServiceLock_);
1917     sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
1918     CHECK_AND_RETURN_RET_LOG(session != nullptr, AVSESSION_ERROR, "session to be got is not existed");
1919 
1920     auto pid = GetCallingPid();
1921     if (pid == session->GetPid()) {
1922         descriptor = session->GetDescriptor();
1923         return AVSESSION_SUCCESS;
1924     }
1925     int32_t err = PermissionChecker::GetInstance().CheckPermission(PermissionChecker::CHECK_SYSTEM_PERMISSION);
1926     if (err != ERR_NONE) {
1927         SLOGE("GetSessionDescriptorsBySessionId: CheckPermission failed!");
1928         HISYSEVENT_SECURITY("CONTROL_PERMISSION_DENIED", "CALLER_UID", GetCallingUid(),
1929             "CALLER_PID", GetCallingUid(), "SESSION_ID", sessionId,
1930             "ERROR_MSG", "avsessionservice getsessiondescriptors by sessionid checkpermission failed");
1931         return err;
1932     }
1933     descriptor = session->GetDescriptor();
1934     return AVSESSION_SUCCESS;
1935 }
1936 
ProcessDescriptorsFromCJSON(std::vector<AVSessionDescriptor> & descriptors,cJSON * valueItem)1937 void AVSessionService::ProcessDescriptorsFromCJSON(std::vector<AVSessionDescriptor>& descriptors, cJSON* valueItem)
1938 {
1939     CHECK_AND_RETURN_LOG(valueItem != nullptr && !cJSON_IsInvalid(valueItem), "valueItem get invalid");
1940 
1941     cJSON* sessionIdItem = cJSON_GetObjectItem(valueItem, "sessionId");
1942     if (sessionIdItem == nullptr || cJSON_IsInvalid(sessionIdItem) || !cJSON_IsString(sessionIdItem)) {
1943         SLOGE("valueItem get sessionId fail");
1944         return;
1945     }
1946     std::string sessionId(sessionIdItem->valuestring);
1947     cJSON* bundleNameItem = cJSON_GetObjectItem(valueItem, "bundleName");
1948     if (bundleNameItem == nullptr || cJSON_IsInvalid(bundleNameItem) || !cJSON_IsString(bundleNameItem)) {
1949         SLOGE("valueItem get bundleName fail");
1950         return;
1951     }
1952     std::string bundleName(bundleNameItem->valuestring);
1953     cJSON* abilityNameItem = cJSON_GetObjectItem(valueItem, "abilityName");
1954     if (abilityNameItem == nullptr || cJSON_IsInvalid(abilityNameItem) || !cJSON_IsString(abilityNameItem)) {
1955         SLOGE("valueItem get abilityName fail");
1956         return;
1957     }
1958     std::string abilityName(abilityNameItem->valuestring);
1959 
1960     AVSessionDescriptor descriptor;
1961     descriptor.sessionId_ = sessionId;
1962     descriptor.elementName_.SetBundleName(std::string(bundleNameItem->valuestring));
1963     descriptor.elementName_.SetAbilityName(std::string(abilityNameItem->valuestring));
1964     descriptors.push_back(descriptor);
1965 }
1966 
GetHistoricalSessionDescriptorsFromFile(std::vector<AVSessionDescriptor> & descriptors)1967 int32_t AVSessionService::GetHistoricalSessionDescriptorsFromFile(std::vector<AVSessionDescriptor>& descriptors)
1968 {
1969     std::string oldSortContent;
1970     if (!LoadStringFromFileEx(GetAVSortDir(), oldSortContent)) {
1971         SLOGE("GetHistoricalSessionDescriptorsFromFile read sort fail, Return!");
1972         return AVSESSION_ERROR;
1973     }
1974 
1975     cJSON* sortValuesArray = cJSON_Parse(oldSortContent.c_str());
1976     CHECK_AND_RETURN_RET_LOG(sortValuesArray != nullptr, AVSESSION_ERROR, "json object is null");
1977     if (cJSON_IsInvalid(sortValuesArray) || !cJSON_IsArray(sortValuesArray)) {
1978         SLOGE("parse json not valid");
1979         cJSON_Delete(sortValuesArray);
1980         return AVSESSION_ERROR;
1981     }
1982 
1983     cJSON* valueItem = nullptr;
1984     cJSON_ArrayForEach(valueItem, sortValuesArray) {
1985         ProcessDescriptorsFromCJSON(descriptors, valueItem);
1986     }
1987     if (descriptors.size() == 0 && GetContainer().GetAllSessions().size() == 0) {
1988         SLOGE("GetHistoricalSessionDescriptorsFromFile read empty, return!");
1989     }
1990     cJSON_Delete(sortValuesArray);
1991     return AVSESSION_SUCCESS;
1992 }
1993 
GetColdStartSessionDescriptors(std::vector<AVSessionDescriptor> & descriptors)1994 int32_t AVSessionService::GetColdStartSessionDescriptors(std::vector<AVSessionDescriptor>& descriptors)
1995 {
1996     std::lock_guard sortFileLockGuard(sessionFileLock_);
1997     std::vector<AVSessionDescriptor> tempDescriptors;
1998     GetHistoricalSessionDescriptorsFromFile(tempDescriptors);
1999     for (auto iterator = tempDescriptors.begin(); iterator != tempDescriptors.end(); ++iterator) {
2000         descriptors.push_back(*iterator);
2001     }
2002 
2003     return AVSESSION_SUCCESS;
2004 }
2005 
GetHistoricalSessionDescriptors(int32_t maxSize,std::vector<AVSessionDescriptor> & descriptors)2006 int32_t AVSessionService::GetHistoricalSessionDescriptors(int32_t maxSize,
2007                                                           std::vector<AVSessionDescriptor>& descriptors)
2008 {
2009     std::lock_guard sortFileLockGuard(sessionFileLock_);
2010     std::vector<AVSessionDescriptor> tempDescriptors;
2011     GetHistoricalSessionDescriptorsFromFile(tempDescriptors);
2012     if (maxSize < 0 || maxSize > maxHistoryNums_) {
2013         maxSize = unSetHistoryNum;
2014     }
2015     for (auto iterator = tempDescriptors.begin(); iterator != tempDescriptors.end(); ++iterator) {
2016         if (descriptors.size() >= (size_t)maxSize) {
2017             break;
2018         }
2019         std::string sessionId(iterator->sessionId_);
2020         auto session = GetContainer().GetSessionById(sessionId);
2021         if (session != nullptr) {
2022             SLOGE("GetHistoricalSessionDescriptorsFromFile find session alive, sessionId=%{public}s",
2023                 AVSessionUtils::GetAnonySessionId(sessionId).c_str());
2024             continue;
2025         }
2026         descriptors.push_back(*iterator);
2027     }
2028 
2029     return AVSESSION_SUCCESS;
2030 }
2031 
2032 // LCOV_EXCL_START
ProcessAvQueueInfosFromCJSON(std::vector<AVQueueInfo> & avQueueInfos,cJSON * valueItem)2033 void AVSessionService::ProcessAvQueueInfosFromCJSON(std::vector<AVQueueInfo>& avQueueInfos, cJSON* valueItem)
2034 {
2035     CHECK_AND_RETURN_LOG(valueItem != nullptr && !cJSON_IsInvalid(valueItem), "get valueItem invalid");
2036     cJSON* bundleNameItem = cJSON_GetObjectItem(valueItem, "bundleName");
2037     if (bundleNameItem == nullptr || cJSON_IsInvalid(bundleNameItem) || !cJSON_IsString(bundleNameItem)) {
2038         SLOGE("valueItem get bundleName fail");
2039         return;
2040     }
2041     cJSON* avQueueNameItem = cJSON_GetObjectItem(valueItem, "avQueueName");
2042     if (avQueueNameItem == nullptr || cJSON_IsInvalid(avQueueNameItem) || !cJSON_IsString(avQueueNameItem)) {
2043         SLOGE("valueItem get avQueueName fail");
2044         return;
2045     }
2046     cJSON* avQueueIdItem = cJSON_GetObjectItem(valueItem, "avQueueId");
2047     if (avQueueIdItem == nullptr || cJSON_IsInvalid(avQueueIdItem) || !cJSON_IsString(avQueueIdItem)) {
2048         SLOGE("valueItem get avQueueId fail");
2049         return;
2050     }
2051     cJSON* imageDirItem = cJSON_GetObjectItem(valueItem, "avQueueImageDir");
2052     if (imageDirItem == nullptr || cJSON_IsInvalid(imageDirItem) || !cJSON_IsString(imageDirItem)) {
2053         SLOGE("valueItem get avQueueImageDir fail");
2054         return;
2055     }
2056     cJSON* imageNameItem = cJSON_GetObjectItem(valueItem, "avQueueImageName");
2057     if (imageNameItem == nullptr || cJSON_IsInvalid(imageNameItem) || !cJSON_IsString(imageNameItem)) {
2058         SLOGE("valueItem get avQueueImageName fail");
2059         return;
2060     }
2061     cJSON* imageUri = cJSON_GetObjectItem(valueItem, "avQueueImageUri");
2062     if (imageUri == nullptr || cJSON_IsInvalid(imageUri) || !cJSON_IsString(imageUri)) {
2063         SLOGE("valueItem get avQueueImageUri fail");
2064         return;
2065     }
2066     AVQueueInfo avQueueInfo;
2067     avQueueInfo.SetBundleName(std::string(bundleNameItem->valuestring));
2068     avQueueInfo.SetAVQueueName(std::string(avQueueNameItem->valuestring));
2069     avQueueInfo.SetAVQueueId(std::string(avQueueIdItem->valuestring));
2070     std::shared_ptr<AVSessionPixelMap> avQueuePixelMap = std::make_shared<AVSessionPixelMap>();
2071     AVSessionUtils::ReadImageFromFile(avQueuePixelMap, std::string(imageDirItem->valuestring),
2072         std::string(imageNameItem->valuestring));
2073     avQueueInfo.SetAVQueueImage(avQueuePixelMap);
2074     avQueueInfo.SetAVQueueImageUri(std::string(imageUri->valuestring));
2075     avQueueInfos.push_back(avQueueInfo);
2076 }
2077 // LCOV_EXCL_STOP
2078 
2079 // LCOV_EXCL_START
GetHistoricalAVQueueInfos(int32_t maxSize,int32_t maxAppSize,std::vector<AVQueueInfo> & avQueueInfos)2080 int32_t AVSessionService::GetHistoricalAVQueueInfos(int32_t maxSize, int32_t maxAppSize,
2081                                                     std::vector<AVQueueInfo>& avQueueInfos)
2082 {
2083     std::lock_guard avQueueFileLockGuard(avQueueFileLock_);
2084     std::string oldAVQueueInfoContent;
2085     std::vector<AVQueueInfo> tempAVQueueInfos;
2086     if (!LoadStringFromFileEx(GetAVQueueDir(), oldAVQueueInfoContent)) {
2087         SLOGE("GetHistoricalAVQueueInfos read avqueueinfo fail, Return!");
2088         return AVSESSION_ERROR;
2089     }
2090 
2091     cJSON* avQueueValuesArray = cJSON_Parse(oldAVQueueInfoContent.c_str());
2092     CHECK_AND_RETURN_RET_LOG(avQueueValuesArray != nullptr, AVSESSION_ERROR, "json object is null");
2093     if (cJSON_IsInvalid(avQueueValuesArray) || !cJSON_IsArray(avQueueValuesArray)) {
2094         SLOGE("parse json not valid");
2095         cJSON_Delete(avQueueValuesArray);
2096         return AVSESSION_ERROR;
2097     }
2098     cJSON* valueItem = nullptr;
2099     cJSON_ArrayForEach(valueItem, avQueueValuesArray) {
2100         ProcessAvQueueInfosFromCJSON(tempAVQueueInfos, valueItem);
2101     }
2102     for (auto iterator = tempAVQueueInfos.begin(); iterator != tempAVQueueInfos.end(); ++iterator) {
2103         avQueueInfos.push_back(*iterator);
2104     }
2105     cJSON_Delete(avQueueValuesArray);
2106     return AVSESSION_SUCCESS;
2107 }
2108 // LCOV_EXCL_STOP
2109 
2110 // LCOV_EXCL_START
InsertAvQueueInfoToCJSONAndPrint(const std::string & bundleName,const AVMetaData & meta,const int32_t userId,cJSON * valuesArray)2111 bool AVSessionService::InsertAvQueueInfoToCJSONAndPrint(const std::string &bundleName,
2112     const AVMetaData& meta, const int32_t userId, cJSON* valuesArray)
2113 {
2114     CHECK_AND_RETURN_RET_LOG(valuesArray != nullptr, false, "get valuesArray nullptr");
2115     cJSON* newValue = cJSON_CreateObject();
2116     cJSON_AddStringToObject(newValue, "bundleName", bundleName.c_str());
2117     cJSON_AddStringToObject(newValue, "avQueueName", meta.GetAVQueueName().c_str());
2118     cJSON_AddStringToObject(newValue, "avQueueId", meta.GetAVQueueId().c_str());
2119     std::shared_ptr<AVSessionPixelMap> innerPixelMap = meta.GetAVQueueImage();
2120     std::string fileDir = AVSessionUtils::GetFixedPathName(userId);
2121     std::string fileName = bundleName + "_" + meta.GetAVQueueId() + AVSessionUtils::GetFileSuffix();
2122     if (innerPixelMap != nullptr) {
2123         AVSessionUtils::WriteImageToFile(innerPixelMap, fileDir, fileName);
2124         innerPixelMap->Clear();
2125     }
2126     cJSON_AddStringToObject(newValue, "avQueueImageDir", fileDir.c_str());
2127     cJSON_AddStringToObject(newValue, "avQueueImageName", fileName.c_str());
2128     cJSON_AddStringToObject(newValue, "avQueueImageUri", meta.GetAVQueueImageUri().c_str());
2129     if (cJSON_IsInvalid(newValue)) {
2130         SLOGE("get valuesArray nullptr");
2131         return false;
2132     }
2133     if (cJSON_GetArraySize(valuesArray) <= 0) {
2134         cJSON_AddItemToArray(valuesArray, newValue);
2135     } else {
2136         cJSON_InsertItemInArray(valuesArray, 0, newValue);
2137     }
2138     if (cJSON_IsInvalid(valuesArray)) {
2139         SLOGE("get newValueArray invalid");
2140         return false;
2141     }
2142 
2143     char* newAvqueueContent = cJSON_Print(valuesArray);
2144     if (newAvqueueContent == nullptr) {
2145         SLOGE("newValueArray print fail");
2146         return false;
2147     }
2148     std::string newAvqueueContentStr(newAvqueueContent);
2149     if (!SaveStringToFileEx(GetAVQueueDir(userId), newAvqueueContentStr)) {
2150         SLOGE("SaveStringToFileEx failed when refresh focus session sort!");
2151         cJSON_free(newAvqueueContent);
2152         return false;
2153     }
2154     cJSON_free(newAvqueueContent);
2155     return true;
2156 }
2157 // LCOV_EXCL_STOP
2158 
2159 // LCOV_EXCL_START
SaveAvQueueInfo(std::string & oldContent,const std::string & bundleName,const AVMetaData & meta,const int32_t userId)2160 bool AVSessionService::SaveAvQueueInfo(std::string& oldContent, const std::string &bundleName,
2161     const AVMetaData& meta, const int32_t userId)
2162 {
2163     cJSON* valuesArray = cJSON_Parse(oldContent.c_str());
2164     CHECK_AND_RETURN_RET_LOG(valuesArray != nullptr, false, "json parse get nullptr");
2165     if (cJSON_IsInvalid(valuesArray) || !cJSON_IsArray(valuesArray)) {
2166         SLOGE("get value array invalid but createNew");
2167         cJSON_Delete(valuesArray);
2168         valuesArray = nullptr;
2169         valuesArray = cJSON_CreateArray();
2170         CHECK_AND_RETURN_RET_LOG(valuesArray != nullptr, false, "create array json again fail");
2171     }
2172 
2173     int arraySize = cJSON_GetArraySize(valuesArray);
2174     for (int i = arraySize - 1; i >= 0; i--) {
2175         cJSON* valueItem = cJSON_GetArrayItem(valuesArray, i);
2176         CHECK_AND_CONTINUE(valueItem != nullptr && !cJSON_IsInvalid(valueItem));
2177         cJSON* bundleNameItem = cJSON_GetObjectItem(valueItem, "bundleName");
2178         cJSON* avQueueIdItem = cJSON_GetObjectItem(valueItem, "avQueueId");
2179         if (bundleNameItem == nullptr || avQueueIdItem == nullptr || cJSON_IsInvalid(bundleNameItem) ||
2180             !cJSON_IsString(bundleNameItem) || cJSON_IsInvalid(avQueueIdItem) || !cJSON_IsString(avQueueIdItem)) {
2181             continue;
2182         }
2183         if (strcmp(bundleNameItem->valuestring, bundleName.c_str()) == 0 &&
2184             strcmp(avQueueIdItem->valuestring, meta.GetAVQueueId().c_str()) == 0) {
2185             CHECK_AND_RETURN_RET_LOG(i != 0, false, "avqueue:%{public}s is first", meta.GetAVQueueId().c_str());
2186             cJSON_DeleteItemFromArray(valuesArray, i);
2187         }
2188     }
2189     if (cJSON_GetArraySize(valuesArray) >= maxAVQueueInfoLen) {
2190         cJSON* valueItem = cJSON_GetArrayItem(valuesArray, cJSON_GetArraySize(valuesArray) - 1);
2191         DeleteAVQueueImage(valueItem);
2192         cJSON_DeleteItemFromArray(valuesArray, cJSON_GetArraySize(valuesArray) - 1);
2193     }
2194 
2195     bool ret = InsertAvQueueInfoToCJSONAndPrint(bundleName, meta, userId, valuesArray);
2196     cJSON_Delete(valuesArray);
2197     return ret;
2198 }
2199 // LCOV_EXCL_STOP
2200 
2201 // LCOV_EXCL_START
DeleteAVQueueImage(cJSON * item)2202 void AVSessionService::DeleteAVQueueImage(cJSON* item)
2203 {
2204     if (item == nullptr || cJSON_IsInvalid(item)) {
2205         return;
2206     }
2207     cJSON* imageDirItem = cJSON_GetObjectItem(item, "avQueueImageDir");
2208     cJSON* imageNameItem = cJSON_GetObjectItem(item, "avQueueImageName");
2209 
2210     if (imageDirItem == nullptr || cJSON_IsInvalid(imageDirItem) || !cJSON_IsString(imageDirItem)) {
2211         SLOGE("invalid imageDirItem");
2212         return;
2213     }
2214 
2215     if (imageNameItem == nullptr || cJSON_IsInvalid(imageNameItem) || !cJSON_IsString(imageNameItem)) {
2216         SLOGE("invalid imageNameItem");
2217         return;
2218     }
2219 
2220     std::string fileName = std::string(imageDirItem->valuestring) + std::string(imageNameItem->valuestring);
2221     AVSessionUtils::DeleteFile(fileName);
2222 }
2223 // LCOV_EXCL_STOP
2224 
2225 // LCOV_EXCL_START
AddAvQueueInfoToFile(AVSessionItem & session)2226 void AVSessionService::AddAvQueueInfoToFile(AVSessionItem& session)
2227 {
2228     // check is this session support playmusiclist intent
2229     std::lock_guard lockGuard(sessionServiceLock_);
2230     std::string bundleName = session.GetBundleName();
2231     std::string supportModule;
2232     std::string profile;
2233     if (!BundleStatusAdapter::GetInstance().IsSupportPlayIntent(bundleName, supportModule, profile)) {
2234         SLOGE("bundleName=%{public}s does not support play intent", bundleName.c_str());
2235         return;
2236     }
2237     AVMetaData meta = session.GetMetaData();
2238     if (meta.GetAVQueueId().empty() || meta.GetAVQueueName().empty()) {
2239         SLOGI("AddAvQueueInfoToFile avqueueinfo empty, return");
2240         DoMetadataImgClean(meta);
2241         return;
2242     }
2243     std::lock_guard avQueueFileLockGuard(avQueueFileLock_);
2244     std::string oldContent;
2245     int32_t userId = session.GetUserId();
2246     SLOGI("AddAvQueueInfoToFile for bundleName:%{public}s,userId:%{public}d", bundleName.c_str(), userId);
2247     if (!LoadStringFromFileEx(GetAVQueueDir(userId), oldContent)) {
2248         SLOGE("AddAvQueueInfoToFile read avqueueinfo fail, Return!");
2249         DoMetadataImgClean(meta);
2250         return;
2251     }
2252     if (!SaveAvQueueInfo(oldContent, bundleName, meta, userId)) {
2253         SLOGE("SaveAvQueueInfo same avqueueinfo, Return!");
2254         DoMetadataImgClean(meta);
2255         return;
2256     }
2257     DoMetadataImgClean(meta);
2258 }
2259 // LCOV_EXCL_STOP
2260 
DoMetadataImgClean(AVMetaData & data)2261 void AVSessionService::DoMetadataImgClean(AVMetaData& data)
2262 {
2263     SLOGI("clear media img in DoMetadataImgClean");
2264     std::shared_ptr<AVSessionPixelMap> innerQueuePixelMap = data.GetAVQueueImage();
2265     if (innerQueuePixelMap != nullptr) {
2266         innerQueuePixelMap->Clear();
2267     }
2268     std::shared_ptr<AVSessionPixelMap> innerMediaPixelMap = data.GetMediaImage();
2269     if (innerMediaPixelMap != nullptr) {
2270         innerMediaPixelMap->Clear();
2271     }
2272 }
2273 
StartAVPlayback(const std::string & bundleName,const std::string & assetId,const std::string & deviceId)2274 int32_t AVSessionService::StartAVPlayback(const std::string& bundleName, const std::string& assetId,
2275     const std::string& deviceId)
2276 {
2277     auto uid = GetCallingUid();
2278     auto CallerBundleName = BundleStatusAdapter::GetInstance().GetBundleNameFromUid(uid);
2279     StartPlayType startPlayType = StartPlayType::APP;
2280     if (uid == BLUETOOTH_UID) {
2281         startPlayType = StartPlayType::BLUETOOTH;
2282     }
2283     StartPlayInfo startPlayInfo;
2284     startPlayInfo.setBundleName(CallerBundleName);
2285     startPlayInfo.setDeviceId(deviceId);
2286 
2287     std::unique_ptr<AVSessionDynamicLoader> dynamicLoader = std::make_unique<AVSessionDynamicLoader>();
2288 
2289     typedef int32_t (*StartAVPlaybackFunc)(const std::string& bundleName, const std::string& assetId,
2290         const StartPlayInfo startPlayInfo, StartPlayType startPlayType);
2291     StartAVPlaybackFunc startAVPlayback =
2292         reinterpret_cast<StartAVPlaybackFunc>(dynamicLoader->GetFuntion(
2293             AVSESSION_DYNAMIC_INSIGHT_LIBRARY_PATH, "StartAVPlaybackWithId"));
2294     if (startAVPlayback) {
2295 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
2296         ReportSessionControl(bundleName, CONTROL_COLD_START);
2297 #endif
2298         return (*startAVPlayback)(bundleName, assetId, startPlayInfo, startPlayType);
2299     }
2300     SLOGE("StartAVPlayback fail");
2301     return AVSESSION_ERROR;
2302 }
2303 
StartAVPlayback(const std::string & bundleName,const std::string & assetId)2304 int32_t AVSessionService::StartAVPlayback(const std::string& bundleName, const std::string& assetId)
2305 {
2306     auto uid = GetCallingUid();
2307     auto CallerBundleName = BundleStatusAdapter::GetInstance().GetBundleNameFromUid(uid);
2308     StartPlayType startPlayType = StartPlayType::APP;
2309     if (uid == BLUETOOTH_UID) {
2310         startPlayType = StartPlayType::BLUETOOTH;
2311     }
2312     StartPlayInfo startPlayInfo;
2313     startPlayInfo.setBundleName(CallerBundleName);
2314     std::unique_ptr<AVSessionDynamicLoader> dynamicLoader = std::make_unique<AVSessionDynamicLoader>();
2315     if (dynamicLoader == nullptr) {
2316         SLOGI("dynamicLoader is null");
2317         return AVSESSION_ERROR;
2318     }
2319 
2320     typedef int32_t (*StartAVPlaybackFunc)(const std::string& bundleName, const std::string& assetId,
2321         const StartPlayInfo startPlayInfo, StartPlayType startPlayType);
2322     StartAVPlaybackFunc startAVPlayback =
2323         reinterpret_cast<StartAVPlaybackFunc>(dynamicLoader->GetFuntion(
2324             AVSESSION_DYNAMIC_INSIGHT_LIBRARY_PATH, "StartAVPlaybackWithId"));
2325     if (startAVPlayback) {
2326 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
2327         ReportSessionControl(bundleName, CONTROL_COLD_START);
2328 #endif
2329         return (*startAVPlayback)(bundleName, assetId, startPlayInfo, startPlayType);
2330     }
2331     SLOGE("StartAVPlayback fail");
2332     return AVSESSION_ERROR;
2333 }
2334 
CreateNewControllerForSession(pid_t pid,sptr<AVSessionItem> & session)2335 sptr<AVControllerItem> AVSessionService::CreateNewControllerForSession(pid_t pid, sptr<AVSessionItem>& session)
2336 {
2337     SLOGI("pid=%{public}d sessionId=%{public}s", pid,
2338         AVSessionUtils::GetAnonySessionId(session->GetSessionId()).c_str());
2339     sptr<AVControllerItem> result = new(std::nothrow) AVControllerItem(pid, session, session->GetUserId());
2340     if (result == nullptr) {
2341         SLOGE("malloc controller failed");
2342         return nullptr;
2343     }
2344     result->SetServiceCallbackForRelease([this](AVControllerItem& controller) { HandleControllerRelease(controller); });
2345     session->AddController(pid, result);
2346     if (AbilityHasSession(pid)) {
2347         SLOGI("set isfromsession for pid %{public}d", static_cast<int>(pid));
2348         result->isFromSession_ = true;
2349     }
2350     return result;
2351 }
2352 
2353 // LCOV_EXCL_START
GetSubNode(const cJSON * nodeItem,const std::string & name)2354 const cJSON* AVSessionService::GetSubNode(const cJSON* nodeItem, const std::string& name)
2355 {
2356     if (nodeItem == nullptr || cJSON_IsInvalid(nodeItem)) {
2357         SLOGE("json node is invalid");
2358         return nullptr;
2359     }
2360 
2361     if (name.empty()) {
2362         SLOGE("name is invalid");
2363         return nodeItem;
2364     }
2365 
2366     const cJSON* subItem = cJSON_GetObjectItem(nodeItem, name.c_str());
2367     if (subItem == nullptr || cJSON_IsInvalid(subItem)) {
2368         SLOGE("%{public}s is not exist in json", name.c_str());
2369         return nullptr;
2370     }
2371     return subItem;
2372 }
2373 // LCOV_EXCL_STOP
2374 
IsHistoricalSession(const std::string & sessionId)2375 bool AVSessionService::IsHistoricalSession(const std::string& sessionId)
2376 {
2377     {
2378         std::string sortContent;
2379         std::lock_guard sortFileLockGuard(sessionFileLock_);
2380         if (!LoadStringFromFileEx(GetAVSortDir(), sortContent)) {
2381             SLOGE("IsHistoricalSession read sort failed, filename=%{public}s", SORT_FILE_NAME);
2382             return false;
2383         }
2384         if (sortContent.find(sessionId) == string::npos) {
2385             SLOGE("IsHistoricalSession find session no sort, sessionId=%{public}s",
2386                 AVSessionUtils::GetAnonySessionId(sessionId).c_str());
2387             return false;
2388         }
2389     }
2390 
2391     auto session = GetContainer().GetSessionById(sessionId);
2392     if (session != nullptr) {
2393         SLOGE("IsHistoricalSession find session alive, sessionId=%{public}s",
2394             AVSessionUtils::GetAnonySessionId(sessionId).c_str());
2395         return false;
2396     }
2397     SLOGE("IsHistoricalSession find session historical, sessionId=%{public}s",
2398         AVSessionUtils::GetAnonySessionId(sessionId).c_str());
2399     return true;
2400 }
2401 
GetDefaultAbilityElementNameFromCJSON(std::string & sortContent,std::string & bundleName,std::string & abilityName)2402 bool AVSessionService::GetDefaultAbilityElementNameFromCJSON(std::string& sortContent,
2403     std::string& bundleName, std::string& abilityName)
2404 {
2405     cJSON* sortValuesArray = cJSON_Parse(sortContent.c_str());
2406     CHECK_AND_RETURN_RET_LOG(sortValuesArray != nullptr, false, "json object is null");
2407     if (cJSON_IsInvalid(sortValuesArray) || !cJSON_IsArray(sortValuesArray)) {
2408         SLOGE("sortValuesArray get invalid");
2409         cJSON_Delete(sortValuesArray);
2410         return false;
2411     }
2412 
2413     cJSON* sortValueItem = nullptr;
2414     cJSON_ArrayForEach(sortValueItem, sortValuesArray) {
2415         CHECK_AND_CONTINUE(sortValueItem != nullptr && !cJSON_IsInvalid(sortValueItem));
2416         cJSON* sessionIdItem = cJSON_GetObjectItem(sortValueItem, "sessionId");
2417         CHECK_AND_CONTINUE(sessionIdItem != nullptr &&
2418             !cJSON_IsInvalid(sessionIdItem) && cJSON_IsString(sessionIdItem));
2419         auto session = GetContainer().GetSessionById(std::string(sessionIdItem->valuestring));
2420         if (session == nullptr) {
2421             cJSON* bundleNameItem = cJSON_GetObjectItem(sortValueItem, "bundleName");
2422             cJSON* abilityNameItem = cJSON_GetObjectItem(sortValueItem, "abilityName");
2423             CHECK_AND_CONTINUE(bundleNameItem != nullptr &&
2424                 !cJSON_IsInvalid(bundleNameItem) && cJSON_IsString(bundleNameItem));
2425             CHECK_AND_CONTINUE(abilityNameItem != nullptr &&
2426                 !cJSON_IsInvalid(abilityNameItem) && cJSON_IsString(abilityNameItem));
2427             bundleName.assign(bundleNameItem->valuestring);
2428             abilityName.assign(abilityNameItem->valuestring);
2429             break;
2430         } else {
2431             SLOGE("Default start alive %{public}s",
2432                 AVSessionUtils::GetAnonySessionId(std::string(sessionIdItem->valuestring)).c_str());
2433             cJSON_Delete(sortValuesArray);
2434             return false;
2435         }
2436     }
2437     cJSON_Delete(sortValuesArray);
2438     return true;
2439 }
2440 
StartDefaultAbilityByCall(std::string & sessionId)2441 int32_t AVSessionService::StartDefaultAbilityByCall(std::string& sessionId)
2442 {
2443     std::string bundleName = DEFAULT_BUNDLE_NAME;
2444     std::string abilityName = DEFAULT_ABILITY_NAME;
2445     std::string sortContent;
2446     {
2447         std::lock_guard sortFileLockGuard(sessionFileLock_);
2448         if (!LoadStringFromFileEx(GetAVSortDir(), sortContent)) {
2449             SLOGE("GetAllSessionDescriptors read sort fail! ");
2450             return AVSESSION_ERROR;
2451         }
2452     }
2453     if (!sortContent.empty()) {
2454         if (!GetDefaultAbilityElementNameFromCJSON(sortContent, bundleName, abilityName)) {
2455             SLOGE("GetDefaultAbilityElementNameFromCJSON fail");
2456             return AVSESSION_ERROR;
2457         }
2458     }
2459     std::shared_ptr<AbilityManagerAdapter> ability = nullptr;
2460     {
2461         std::lock_guard lockGuard(abilityManagerLock_);
2462         auto it = abilityManager_.find(bundleName + abilityName);
2463         if (it != abilityManager_.end()) {
2464             ability = it->second;
2465         } else {
2466             ability = std::make_shared<AbilityManagerAdapter>(bundleName, abilityName);
2467             if (ability == nullptr) {
2468                 return ERR_NO_MEMORY;
2469             }
2470             abilityManager_[bundleName + abilityName] = ability;
2471         }
2472     }
2473     if (ability == nullptr) {
2474         return AVSESSION_ERROR;
2475     }
2476     int32_t ret = ability->StartAbilityByCall(sessionId);
2477     if (ret != ERR_START_ABILITY_IS_RUNNING) {
2478         abilityManager_.erase(bundleName + abilityName);
2479     }
2480     return ret;
2481 }
2482 
GetElementNameBySessionIdFromCJSON(std::string & sortContent,const std::string & sessionIdNeeded,std::string & bundleName,std::string & abilityName)2483 bool AVSessionService::GetElementNameBySessionIdFromCJSON(std::string& sortContent, const std::string& sessionIdNeeded,
2484     std::string& bundleName, std::string& abilityName)
2485 {
2486     cJSON* sortValuesArray = cJSON_Parse(sortContent.c_str());
2487     CHECK_AND_RETURN_RET_LOG(sortValuesArray != nullptr, false, "json object is null");
2488     if (cJSON_IsInvalid(sortValuesArray) || !cJSON_IsArray(sortValuesArray)) {
2489         SLOGE("sortValuesArray get invalid");
2490         cJSON_Delete(sortValuesArray);
2491         return false;
2492     }
2493 
2494     cJSON* sortValueItem = nullptr;
2495     cJSON_ArrayForEach(sortValueItem, sortValuesArray) {
2496         CHECK_AND_CONTINUE(sortValueItem != nullptr && !cJSON_IsInvalid(sortValueItem));
2497         cJSON* sessionIdItem = cJSON_GetObjectItem(sortValueItem, "sessionId");
2498         CHECK_AND_CONTINUE(sessionIdItem != nullptr &&
2499             !cJSON_IsInvalid(sessionIdItem) && cJSON_IsString(sessionIdItem));
2500         if (strcmp(sessionIdNeeded.c_str(), sessionIdItem->valuestring) == 0) {
2501             cJSON* bundleNameItem = cJSON_GetObjectItem(sortValueItem, "bundleName");
2502             cJSON* abilityNameItem = cJSON_GetObjectItem(sortValueItem, "abilityName");
2503             CHECK_AND_CONTINUE(bundleNameItem != nullptr &&
2504                 !cJSON_IsInvalid(bundleNameItem) && cJSON_IsString(bundleNameItem));
2505             CHECK_AND_CONTINUE(abilityNameItem != nullptr &&
2506                 !cJSON_IsInvalid(abilityNameItem) && cJSON_IsString(abilityNameItem));
2507             bundleName.assign(bundleNameItem->valuestring);
2508             abilityName.assign(abilityNameItem->valuestring);
2509             break;
2510         }
2511     }
2512     cJSON_Delete(sortValuesArray);
2513     return true;
2514 }
2515 
StartAbilityByCall(const std::string & sessionIdNeeded,std::string & sessionId)2516 int32_t AVSessionService::StartAbilityByCall(const std::string& sessionIdNeeded, std::string& sessionId)
2517 {
2518     std::string content;
2519 
2520     {
2521         std::lock_guard sortFileLockGuard(sessionFileLock_);
2522         if (!LoadStringFromFileEx(GetAVSortDir(), content)) {
2523             SLOGE("LoadStringFromFile failed, filename=%{public}s", SORT_FILE_NAME);
2524             return AVSESSION_ERROR;
2525         }
2526     }
2527 
2528     std::string bundleName;
2529     std::string abilityName;
2530 
2531     if (!GetElementNameBySessionIdFromCJSON(content, sessionIdNeeded, bundleName, abilityName)) {
2532         SLOGE("parse json failed, sessionId=%{public}s",
2533             AVSessionUtils::GetAnonySessionId(sessionIdNeeded).c_str());
2534         return AVSESSION_ERROR;
2535     }
2536     if (bundleName.empty() || abilityName.empty()) {
2537         SLOGE("Get bundle name & ability name failed, sessionId=%{public}s",
2538             AVSessionUtils::GetAnonySessionId(sessionIdNeeded).c_str());
2539         return AVSESSION_ERROR;
2540     }
2541 
2542     std::shared_ptr<AbilityManagerAdapter> ability = nullptr;
2543     {
2544         std::lock_guard lockGuard(abilityManagerLock_);
2545         auto it = abilityManager_.find(bundleName + abilityName);
2546         if (it != abilityManager_.end()) {
2547             ability = it->second;
2548         } else {
2549             ability = std::make_shared<AbilityManagerAdapter>(bundleName, abilityName);
2550             if (ability == nullptr) {
2551                 return ERR_NO_MEMORY;
2552             }
2553             abilityManager_[bundleName + abilityName] = ability;
2554         }
2555     }
2556     if (ability == nullptr) {
2557         return AVSESSION_ERROR;
2558     }
2559     int32_t ret = ability->StartAbilityByCall(sessionId);
2560     if (ret != ERR_START_ABILITY_IS_RUNNING) {
2561         abilityManager_.erase(bundleName + abilityName);
2562     }
2563     return ret;
2564 }
2565 
CreateControllerInner(const std::string & sessionId,sptr<IRemoteObject> & object)2566 int32_t AVSessionService::CreateControllerInner(const std::string& sessionId, sptr<IRemoteObject>& object)
2567 {
2568     return CreateControllerInner(sessionId, object, -1);
2569 }
2570 
CreateControllerInner(const std::string & sessionId,sptr<IRemoteObject> & object,pid_t pid)2571 int32_t AVSessionService::CreateControllerInner(const std::string& sessionId, sptr<IRemoteObject>& object, pid_t pid)
2572 {
2573     SLOGI("CreateControllerInner for sessionId:%{public}s|%{public}d|%{public}d",
2574         AVSessionUtils::GetAnonySessionId(sessionId).c_str(), pid, GetCallingPid());
2575     sptr<AVSessionItem> session = GetContainer().GetSessionById(sessionId);
2576     if (session == nullptr) {
2577         SLOGE("no session id %{public}s", AVSessionUtils::GetAnonySessionId(sessionId).c_str());
2578         return ERR_SESSION_NOT_EXIST;
2579     }
2580     if (pid < 0 || GetCallingPid() != getpid()) {
2581         pid = GetCallingPid();
2582     }
2583     auto existController = GetPresentController(pid, sessionId);
2584     if (existController != nullptr) {
2585         SLOGI("Controller is already existed.");
2586         object = existController;
2587         return ERR_CONTROLLER_IS_EXIST;
2588     }
2589     sptr<AVControllerItem> newController = CreateNewControllerForSession(pid, session);
2590     if (newController == nullptr) {
2591         SLOGE("Create new controller failed.");
2592         return ERR_NO_MEMORY;
2593     }
2594 
2595     std::lock_guard lockGuard(sessionServiceLock_);
2596     controllers_[pid].push_back(newController);
2597     object = newController;
2598 
2599     return AVSESSION_SUCCESS;
2600 }
2601 
AddSessionListener(pid_t pid,const sptr<ISessionListener> & listener)2602 void AVSessionService::AddSessionListener(pid_t pid, const sptr<ISessionListener>& listener)
2603 {
2604     std::lock_guard lockGuard(sessionListenersLock_);
2605     GetUsersManager().AddSessionListener(pid, listener);
2606 }
2607 
AddSessionListenerForAllUsers(pid_t pid,const sptr<ISessionListener> & listener)2608 void AVSessionService::AddSessionListenerForAllUsers(pid_t pid, const sptr<ISessionListener>& listener)
2609 {
2610     std::lock_guard lockGuard(sessionListenersLock_);
2611     GetUsersManager().AddSessionListenerForAllUsers(pid, listener);
2612 }
2613 
RemoveSessionListener(pid_t pid)2614 void AVSessionService::RemoveSessionListener(pid_t pid)
2615 {
2616     std::lock_guard lockGuard(sessionListenersLock_);
2617     GetUsersManager().RemoveSessionListener(pid);
2618 }
2619 
RegisterSessionListener(const sptr<ISessionListener> & listener)2620 int32_t AVSessionService::RegisterSessionListener(const sptr<ISessionListener>& listener)
2621 {
2622     int32_t userId = GetUsersManager().GetCurrentUserId();
2623     pid_t pid = GetCallingPid();
2624     SLOGI("Enter RegisterSessionListener process for pid:%{public}d and return current userId:%{public}d",
2625         static_cast<int>(pid), userId);
2626     AddSessionListener(pid, listener);
2627     return userId;
2628 }
2629 
RegisterSessionListenerForAllUsers(const sptr<ISessionListener> & listener)2630 int32_t AVSessionService::RegisterSessionListenerForAllUsers(const sptr<ISessionListener>& listener)
2631 {
2632     pid_t pid = GetCallingPid();
2633     SLOGI("Enter RegisterSessionListenerForAllUsers process for pid:%{public}d", static_cast<int>(pid));
2634     AddSessionListenerForAllUsers(pid, listener);
2635     return AVSESSION_SUCCESS;
2636 }
2637 
2638 // LCOV_EXCL_START
GetSessionProcCommand()2639 AVControlCommand AVSessionService::GetSessionProcCommand()
2640 {
2641     AVControlCommand cmd;
2642     if (topSession_ != nullptr) {
2643         sptr<AVSessionItem> procSession = topSession_;
2644         if (IsAncoValid()) {
2645             procSession = topSession_->GetPlayingTime() > ancoSession_->GetPlayingTime() ?
2646                 topSession_ : ancoSession_;
2647         }
2648         auto playbackState = procSession->GetPlaybackState();
2649         cmd.SetCommand(playbackState.GetState() == AVPlaybackState::PLAYBACK_STATE_PLAY ?
2650             AVControlCommand::SESSION_CMD_PAUSE : AVControlCommand::SESSION_CMD_PLAY);
2651     } else if (IsAncoValid()) {
2652         auto state = ancoSession_->GetPlaybackState();
2653         cmd.SetCommand(state.GetState() == AVPlaybackState::PLAYBACK_STATE_PLAY ?
2654             AVControlCommand::SESSION_CMD_PAUSE : AVControlCommand::SESSION_CMD_PLAY);
2655     } else {
2656         cmd.SetCommand(AVControlCommand::SESSION_CMD_PLAY);
2657     }
2658     return cmd;
2659 }
2660 
HandleEventHandlerCallBack()2661 void AVSessionService::HandleEventHandlerCallBack()
2662 {
2663     SLOGI("handle eventHandler callback isFirstPress_=%{public}d, pressCount_:%{public}d", isFirstPress_, pressCount_);
2664     AVControlCommand cmd;
2665     bool shouldColdPlay = false;
2666     {
2667         std::lock_guard lockGuard(sessionServiceLock_);
2668         if (pressCount_ >= THREE_CLICK) {
2669             cmd.SetCommand(AVControlCommand::SESSION_CMD_PLAY_PREVIOUS);
2670         } else if (pressCount_ == DOUBLE_CLICK) {
2671             cmd.SetCommand(AVControlCommand::SESSION_CMD_PLAY_NEXT);
2672         } else if (pressCount_ == ONE_CLICK) {
2673             cmd = GetSessionProcCommand();
2674         } else {
2675             pressCount_ = 0;
2676             isFirstPress_ = true;
2677             SLOGI("press invalid return, topSession alive:%{public}d", static_cast<int>(topSession_ != nullptr));
2678             return;
2679         }
2680         SLOGI("HandleEventHandlerCallBack proc cmd=%{public}d", cmd.GetCommand());
2681         if (!topSession_) {
2682             shouldColdPlay = true;
2683             SLOGI("HandleEventHandlerCallBack checkTop:%{public}d|shouldColdStart=%{public}d",
2684                 static_cast<int>(topSession_ != nullptr), shouldColdPlay);
2685         } else {
2686             if (topSession_->GetDescriptor().sessionTag_ == "external_audio") {
2687                 SLOGI("HandleEventHandlerCallBack this is an external audio");
2688             } else {
2689                 auto keyEvent = MMI::KeyEvent::Create();
2690                 CHECK_AND_RETURN_LOG(keyEvent != nullptr, "handle event keyevent is null");
2691                 CheckSessionHandleKeyEvent(true, cmd, *keyEvent, topSession_);
2692             }
2693         }
2694     }
2695     if (shouldColdPlay) {
2696         HandleSystemKeyColdStart(cmd);
2697     }
2698     pressCount_ = 0;
2699     isFirstPress_ = true;
2700 }
2701 // LCOV_EXCL_STOP
2702 
IsAncoValid()2703 bool AVSessionService::IsAncoValid()
2704 {
2705     std::lock_guard lockGuard(sessionServiceLock_);
2706     return ancoSession_ != nullptr && ancoSession_->IsActive();
2707 }
2708 
CheckSessionHandleKeyEvent(bool procCmd,AVControlCommand cmd,const MMI::KeyEvent & keyEvent,sptr<AVSessionItem> session)2709 bool AVSessionService::CheckSessionHandleKeyEvent(bool procCmd, AVControlCommand cmd,
2710     const MMI::KeyEvent& keyEvent, sptr<AVSessionItem> session)
2711 {
2712     CHECK_AND_RETURN_RET_LOG(session != nullptr, false, "handlevent session is null");
2713     sptr<AVSessionItem> procSession = nullptr;
2714     if (ancoSession_ == nullptr || !ancoSession_->IsActive()) {
2715         procSession = session;
2716     } else {
2717         procSession = session->GetPlayingTime() > ancoSession_->GetPlayingTime() ? session : ancoSession_;
2718     }
2719     CHECK_AND_RETURN_RET_LOG(procSession != nullptr, false, "handlevent session is null");
2720     SLOGI("CheckSessionHandleKeyEvent procSession:%{public}s", procSession->GetBundleName().c_str());
2721     if (procCmd) {
2722         procSession->ExecuteControllerCommand(cmd);
2723         SLOGI("CheckSessionHandleKeyEvent proc cmd:%{public}d", cmd.GetCommand());
2724     } else {
2725         procSession->HandleMediaKeyEvent(keyEvent);
2726         SLOGI("CheckSessionHandleKeyEvent proc event:%{public}d", keyEvent.GetKeyCode());
2727     }
2728     return true;
2729 }
2730 
HandleKeyEvent(const MMI::KeyEvent & keyEvent)2731 int32_t AVSessionService::HandleKeyEvent(const MMI::KeyEvent& keyEvent)
2732 {
2733     if (keyEvent.GetKeyCode() != MMI::KeyEvent::KEYCODE_HEADSETHOOK &&
2734         keyEvent.GetKeyCode() != MMI::KeyEvent::KEYCODE_MEDIA_PLAY_PAUSE) {
2735         std::lock_guard lockGuard(keyEventListLock_);
2736         std::shared_ptr<std::list<sptr<AVSessionItem>>> keyEventList = GetCurKeyEventSessionList();
2737         CHECK_AND_RETURN_RET_LOG(keyEventList != nullptr, AVSESSION_ERROR, "keyEventList ptr nullptr!");
2738         for (const auto& session : *keyEventList) {
2739             session->HandleMediaKeyEvent(keyEvent);
2740             return AVSESSION_SUCCESS;
2741         }
2742     }
2743     if (CheckIfOtherAudioPlaying()) {
2744         SLOGE("control block for OtherAudioPlaying for key:%{public}d", keyEvent.GetKeyCode());
2745         return AVSESSION_SUCCESS;
2746     }
2747     {
2748         std::lock_guard lockGuard(sessionServiceLock_);
2749         if (keyEvent.GetKeyCode() == MMI::KeyEvent::KEYCODE_HEADSETHOOK ||
2750             keyEvent.GetKeyCode() == MMI::KeyEvent::KEYCODE_MEDIA_PLAY_PAUSE) {
2751             pressCount_++;
2752             SLOGI("isFirstPress_=%{public}d", isFirstPress_);
2753             if (isFirstPress_) {
2754                 auto ret = AVSessionEventHandler::GetInstance().AVSessionPostTask([this]() {
2755                     HandleEventHandlerCallBack();
2756                 }, "SendSystemAVKeyEvent", CLICK_TIMEOUT);
2757                 CHECK_AND_RETURN_RET_LOG(ret, AVSESSION_ERROR, "init eventHandler failed");
2758                 isFirstPress_ = false;
2759             }
2760             return AVSESSION_SUCCESS;
2761         }
2762     }
2763 
2764     {
2765         std::lock_guard lockGuard(sessionServiceLock_);
2766         AVControlCommand cmd;
2767         if (topSession_ != nullptr && CheckSessionHandleKeyEvent(false, cmd, keyEvent, topSession_)) {
2768             return AVSESSION_SUCCESS;
2769         }
2770     }
2771     return AVSESSION_CONTINUE;
2772 }
2773 
SendSystemAVKeyEvent(const MMI::KeyEvent & keyEvent,const AAFwk::Want & wantParam)2774 int32_t AVSessionService::SendSystemAVKeyEvent(const MMI::KeyEvent& keyEvent, const AAFwk::Want &wantParam)
2775 {
2776     SLOGI("SendSystemAVKeyEvent get key=%{public}d.", keyEvent.GetKeyCode());
2777     std::string deviceId = wantParam.GetStringParam("deviceId");
2778     int32_t ret = HandleKeyEvent(keyEvent);
2779     if (ret != AVSESSION_CONTINUE) {
2780         return ret;
2781     }
2782     {
2783         int cmd = ConvertKeyCodeToCommand(keyEvent.GetKeyCode());
2784         AVControlCommand controlCommand;
2785         controlCommand.SetCommand(cmd);
2786         SLOGI("topSession get nullptr, check if cold start for cmd %{public}d forRemoteDevice", cmd);
2787         HandleSystemKeyColdStart(controlCommand, deviceId);
2788     }
2789     return AVSESSION_SUCCESS;
2790 }
2791 
SendSystemAVKeyEvent(const MMI::KeyEvent & keyEvent)2792 int32_t AVSessionService::SendSystemAVKeyEvent(const MMI::KeyEvent& keyEvent)
2793 {
2794     SLOGI("SendSystemAVKeyEvent get key=%{public}d.", keyEvent.GetKeyCode());
2795     int32_t ret = HandleKeyEvent(keyEvent);
2796     if (ret != AVSESSION_CONTINUE) {
2797         return ret;
2798     }
2799     {
2800         int cmd = ConvertKeyCodeToCommand(keyEvent.GetKeyCode());
2801         AVControlCommand controlCommand;
2802         controlCommand.SetCommand(cmd);
2803         SLOGI("topSession get nullptr, check if cold start for cmd %{public}d", cmd);
2804         HandleSystemKeyColdStart(controlCommand);
2805     }
2806     return AVSESSION_SUCCESS;
2807 }
2808 
ConvertKeyCodeToCommand(int keyCode)2809 int32_t AVSessionService::ConvertKeyCodeToCommand(int keyCode)
2810 {
2811     auto iter = keyCodeToCommandMap_.find(keyCode);
2812     if (iter != keyCodeToCommandMap_.end()) {
2813         return iter->second;
2814     } else {
2815         return AVControlCommand::SESSION_CMD_PLAY;
2816     }
2817 }
2818 
HandleSystemKeyColdStart(const AVControlCommand & command,const std::string deviceId)2819 void AVSessionService::HandleSystemKeyColdStart(const AVControlCommand &command, const std::string deviceId)
2820 {
2821     SLOGI("cmd=%{public}d with no topsession", command.GetCommand());
2822     // try proc command for first front session
2823     {
2824         std::lock_guard lockGuard(sessionServiceLock_);
2825         std::lock_guard frontLockGuard(sessionFrontLock_);
2826         std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
2827         CHECK_AND_RETURN_LOG(sessionListForFront != nullptr, "sessionListForFront ptr nullptr!");
2828         for (const auto& session : *sessionListForFront) {
2829             CHECK_AND_CONTINUE(session != nullptr);
2830             if (session->GetSessionType() != "voice_call" && session->GetSessionType() != "video_call") {
2831                 auto keyEvent = MMI::KeyEvent::Create();
2832                 CHECK_AND_RETURN_LOG(keyEvent != nullptr, "handle event keyevent is null");
2833                 CheckSessionHandleKeyEvent(true, command, *keyEvent, session);
2834                 SLOGI("ExecuteCommand %{public}d for front session: %{public}s", command.GetCommand(),
2835                       session->GetBundleName().c_str());
2836                 return;
2837             }
2838         }
2839     }
2840 
2841     if (IsAncoValid()) {
2842         SLOGI("ExecuteCommand %{public}d for anco_audio without top and frontlist", command.GetCommand());
2843         ancoSession_->ExecuteControllerCommand(command);
2844         return;
2845     }
2846 
2847     std::vector<AVSessionDescriptor> coldStartDescriptors;
2848     GetColdStartSessionDescriptors(coldStartDescriptors);
2849     CHECK_AND_RETURN_LOG(coldStartDescriptors.size() > 0, "get coldStartDescriptors empty");
2850     // try start play for first history session
2851     if (command.GetCommand() == AVControlCommand::SESSION_CMD_PLAY ||
2852         command.GetCommand() == AVControlCommand::SESSION_CMD_PLAY_NEXT ||
2853         command.GetCommand() == AVControlCommand::SESSION_CMD_PLAY_PREVIOUS) {
2854         sptr<IRemoteObject> object;
2855         int32_t ret = 0;
2856         std::string bundleName = coldStartDescriptors[0].elementName_.GetBundleName();
2857         if (deviceId.length() == 0) {
2858             ret = StartAVPlayback(bundleName, "");
2859         } else {
2860             ret = StartAVPlayback(bundleName, "", deviceId);
2861         }
2862         SLOGI("Cold play %{public}s ret=%{public}d", bundleName.c_str(), ret);
2863     } else {
2864         SLOGI("Cold start command=%{public}d, coldStartDescriptorsSize=%{public}d return", command.GetCommand(),
2865               static_cast<int>(coldStartDescriptors.size()));
2866     }
2867 }
2868 
CheckIfOtherAudioPlaying()2869 bool AVSessionService::CheckIfOtherAudioPlaying()
2870 {
2871     std::vector<int> audioPlayingUids = focusSessionStrategy_.GetAudioPlayingUids();
2872     CHECK_AND_RETURN_RET_LOG(!audioPlayingUids.empty(), false, "no other audio playing quit.");
2873     std::lock_guard lockGuard(sessionServiceLock_);
2874     std::lock_guard frontLockGuard(sessionFrontLock_);
2875     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront();
2876     CHECK_AND_RETURN_RET_LOG(sessionListForFront != nullptr, false, "sessionListForFront ptr nullptr quit");
2877     CHECK_AND_RETURN_RET_LOG(!sessionListForFront->empty() || topSession_ != nullptr || IsAncoValid(), true,
2878         "sessionListForFront and top empty but audio playing, control block");
2879     for (int uid : audioPlayingUids) {
2880         if (GetUsersManager().GetContainerFromAll().UidHasSession(uid)) {
2881             SLOGI("audioplaying but session alive:%{public}d", uid);
2882             return false;
2883         }
2884         std::string bundleNamePlaying = BundleStatusAdapter::GetInstance().GetBundleNameFromUid(uid);
2885         CHECK_AND_RETURN_RET_LOG(topSession_ == nullptr || bundleNamePlaying != topSession_->GetBundleName(),
2886             false, "audioplaying but topBundle alive:%{public}s", bundleNamePlaying.c_str());
2887         for (const auto& session : *sessionListForFront) {
2888             CHECK_AND_CONTINUE(session != nullptr);
2889             if (bundleNamePlaying == session->GetBundleName()) {
2890                 SLOGE("audioplaying but bundle alive:%{public}s", bundleNamePlaying.c_str());
2891                 return false;
2892             }
2893         }
2894         SLOGI("audioPlaying and no session:%{public}d", uid);
2895     }
2896     return true;
2897 }
2898 
SendSystemControlCommand(const AVControlCommand & command)2899 int32_t AVSessionService::SendSystemControlCommand(const AVControlCommand &command)
2900 {
2901     if (CheckIfOtherAudioPlaying()) {
2902         SLOGE("control block for OtherAudioPlaying with cmd:%{public}d", command.GetCommand());
2903         return AVSESSION_SUCCESS;
2904     }
2905     {
2906         std::lock_guard lockGuard(sessionServiceLock_);
2907         SLOGI("SendSystemControlCommand with cmd:%{public}d, topSession alive:%{public}d",
2908               command.GetCommand(), static_cast<int>(topSession_ != nullptr));
2909         if (topSession_) {
2910             CHECK_AND_RETURN_RET_LOG(CommandSendLimit::GetInstance().IsCommandSendEnable(GetCallingPid()),
2911                 ERR_COMMAND_SEND_EXCEED_MAX, "command excuted number exceed max");
2912             auto keyEvent = MMI::KeyEvent::Create();
2913             CHECK_AND_RETURN_RET_LOG(keyEvent != nullptr, AVSESSION_SUCCESS, "handle event keyevent is null");
2914             CheckSessionHandleKeyEvent(true, command, *keyEvent, topSession_);
2915             return AVSESSION_SUCCESS;
2916         }
2917     }
2918     HandleSystemKeyColdStart(command);
2919     return AVSESSION_SUCCESS;
2920 }
2921 
AddClientDeathObserver(pid_t pid,const sptr<IClientDeath> & observer,const sptr<ClientDeathRecipient> recipient)2922 void AVSessionService::AddClientDeathObserver(pid_t pid, const sptr<IClientDeath>& observer,
2923     const sptr<ClientDeathRecipient> recipient)
2924 {
2925     std::lock_guard lockGuard(clientDeathLock_);
2926     clientDeathObservers_[pid] = observer;
2927     clientDeathRecipients_[pid] = recipient;
2928 }
2929 
RemoveClientDeathObserver(pid_t pid)2930 void AVSessionService::RemoveClientDeathObserver(pid_t pid)
2931 {
2932     std::lock_guard lockGuard(clientDeathLock_);
2933     sptr<IClientDeath> observer = clientDeathObservers_[pid];
2934     sptr<ClientDeathRecipient> recipient = clientDeathRecipients_[pid];
2935     if (observer && recipient) {
2936         SLOGI("remove clientDeath recipient for %{public}d", static_cast<int>(pid));
2937         observer->AsObject()->RemoveDeathRecipient(recipient);
2938     }
2939     clientDeathObservers_.erase(pid);
2940     clientDeathRecipients_.erase(pid);
2941 }
2942 
RegisterClientDeathObserver(const sptr<IClientDeath> & observer)2943 int32_t AVSessionService::RegisterClientDeathObserver(const sptr<IClientDeath>& observer)
2944 {
2945     auto pid = GetCallingPid();
2946     auto uid = GetCallingUid();
2947     SLOGI("enter ClientDeathObserver register with recipient point for pid:%{public}d", static_cast<int>(pid));
2948     sptr<ClientDeathRecipient> recipient =
2949         new(std::nothrow) ClientDeathRecipient([this, pid, uid]() { OnClientDied(pid, uid); });
2950     if (recipient == nullptr) {
2951         SLOGE("New ClientDeathRecipient failed.");
2952         HISYSEVENT_FAULT("CONTROL_COMMAND_FAILED", "ERROR_TYPE", "RGS_CLIENT_DEATH_OBSERVER_FAILED",
2953             "ERROR_INFO", "avsession service register client death observer malloc failed");
2954         return AVSESSION_ERROR;
2955     }
2956 
2957     if (!observer->AsObject()->AddDeathRecipient(recipient)) {
2958         SLOGE("add death recipient failed for %{public}d failed", pid);
2959         HISYSEVENT_FAULT("CONTROL_COMMAND_FAILED", "ERROR_TYPE", "RGS_CLIENT_DEATH_FAILED", "CALLING_PID", pid,
2960             "ERROR_INFO", "avsession service register client death observer, add death recipient failed");
2961         return AVSESSION_ERROR;
2962     }
2963 
2964     AddClientDeathObserver(pid, observer, recipient);
2965     return AVSESSION_SUCCESS;
2966 }
2967 
ClearClientResources(pid_t pid,bool continuePlay)2968 void AVSessionService::ClearClientResources(pid_t pid, bool continuePlay)
2969 {
2970     RemoveSessionListener(pid);
2971     {
2972         std::lock_guard lockGuard(sessionServiceLock_);
2973         ClearSessionForClientDiedNoLock(pid, continuePlay);
2974         ClearControllerForClientDiedNoLock(pid);
2975     }
2976     RemoveClientDeathObserver(pid);
2977 }
2978 
Close(void)2979 int32_t AVSessionService::Close(void)
2980 {
2981     auto pid = GetCallingPid();
2982     ClearClientResources(pid, false);
2983     return AVSESSION_SUCCESS;
2984 }
2985 
OnClientDied(pid_t pid,pid_t uid)2986 void AVSessionService::OnClientDied(pid_t pid, pid_t uid)
2987 {
2988     ClearClientResources(pid, true);
2989 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
2990     AVRouter::GetInstance().IsStopCastDiscovery(pid);
2991     if (BundleStatusAdapter::GetInstance().GetBundleNameFromUid(uid) == MEDIA_CONTROL_BUNDLENAME) {
2992         SLOGI("mediacontroller on client die");
2993     }
2994 #endif // CASTPLUS_CAST_ENGINE_ENABLE
2995 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
2996     AVSessionSysEvent::GetInstance().ReportPlayingState(
2997         BundleStatusAdapter::GetInstance().GetBundleNameFromUid(uid));
2998 #endif
2999 }
3000 
3001 // LCOV_EXCL_START
DeleteHistoricalRecord(const std::string & bundleName,int32_t userId)3002 void AVSessionService::DeleteHistoricalRecord(const std::string& bundleName, int32_t userId)
3003 {
3004     std::lock_guard sortFileLockGuard(sessionFileLock_);
3005     userId = userId <= 0 ? GetUsersManager().GetCurrentUserId() : userId;
3006     if (!CheckUserDirValid(userId)) {
3007         SLOGE("DeleteHistoricalRecord target user:%{public}d not valid, return", userId);
3008         return;
3009     }
3010     SLOGI("delete historical record, bundleName=%{public}s, userId=%{public}d", bundleName.c_str(), userId);
3011     std::string oldContent;
3012     if (!LoadStringFromFileEx(GetAVSortDir(userId), oldContent)) {
3013         SLOGE("LoadStringFromFile failed, filename=%{public}s", SORT_FILE_NAME);
3014         return;
3015     }
3016     cJSON* valuesArray = cJSON_Parse(oldContent.c_str());
3017     CHECK_AND_RETURN_LOG(valuesArray != nullptr, "cjson parse nullptr");
3018     if (cJSON_IsInvalid(valuesArray) || !cJSON_IsArray(valuesArray)) {
3019         SLOGE("parse json invalid");
3020         cJSON_Delete(valuesArray);
3021         return;
3022     }
3023     int arraySize = cJSON_GetArraySize(valuesArray);
3024     for (int i = arraySize - 1; i >= 0; i--) {
3025         cJSON* valueItem = cJSON_GetArrayItem(valuesArray, i);
3026         CHECK_AND_CONTINUE(valueItem != nullptr && !cJSON_IsInvalid(valueItem));
3027         cJSON* bundleNameItem = cJSON_GetObjectItem(valueItem, "bundleName");
3028         cJSON* abilityNameItem = cJSON_GetObjectItem(valueItem, "abilityName");
3029         if (bundleNameItem == nullptr || cJSON_IsInvalid(bundleNameItem) || !cJSON_IsString(bundleNameItem) ||
3030             abilityNameItem == nullptr || cJSON_IsInvalid(abilityNameItem) || !cJSON_IsString(abilityNameItem)) {
3031             SLOGI("not contain bundleName or abilityName, pass");
3032             continue;
3033         }
3034         if (strcmp(bundleName.c_str(), bundleNameItem->valuestring) == 0) {
3035             cJSON_DeleteItemFromArray(valuesArray, i);
3036             break;
3037         }
3038     }
3039     char* newContent = cJSON_Print(valuesArray);
3040     if (newContent == nullptr) {
3041         SLOGE("newContent print fail");
3042     } else {
3043         std::string newContentStr(newContent);
3044         if (!SaveStringToFileEx(GetAVSortDir(userId), newContentStr)) {
3045             SLOGE("SaveStringToFileEx failed when refresh focus session sort!");
3046         }
3047         cJSON_free(newContent);
3048     }
3049     cJSON_Delete(valuesArray);
3050 }
3051 // LCOV_EXCL_STOP
3052 
3053 // LCOV_EXCL_START
DeleteAVQueueInfoRecordFromCJSON(std::string & sortContent,const std::string & bundleName,int32_t userId)3054 void AVSessionService::DeleteAVQueueInfoRecordFromCJSON(std::string& sortContent,
3055     const std::string& bundleName, int32_t userId)
3056 {
3057     cJSON* valuesArray = cJSON_Parse(sortContent.c_str());
3058     CHECK_AND_RETURN_LOG(valuesArray != nullptr, "cjson parse nullptr");
3059     if (cJSON_IsInvalid(valuesArray) || !cJSON_IsArray(valuesArray)) {
3060         SLOGE("parse json invalid");
3061         cJSON_Delete(valuesArray);
3062         return;
3063     }
3064     int arraySize = cJSON_GetArraySize(valuesArray);
3065     for (int i = arraySize - 1; i >= 0; i--) {
3066         cJSON* valueItem = cJSON_GetArrayItem(valuesArray, i);
3067         CHECK_AND_CONTINUE(valueItem != nullptr && !cJSON_IsInvalid(valueItem));
3068         cJSON* bundleNameItem = cJSON_GetObjectItem(valueItem, "bundleName");
3069         if (bundleNameItem == nullptr || cJSON_IsInvalid(bundleNameItem) || !cJSON_IsString(bundleNameItem)) {
3070             SLOGI("bundleName from json not valid");
3071             continue;
3072         }
3073         if (strcmp(bundleName.c_str(), bundleNameItem->valuestring) == 0) {
3074             cJSON* avQueueIdItem = cJSON_GetObjectItem(valueItem, "avQueueId");
3075             if (avQueueIdItem == nullptr || cJSON_IsInvalid(avQueueIdItem) || !cJSON_IsString(avQueueIdItem)) {
3076                 SLOGI("avQueueId from json not valid");
3077                 continue;
3078             }
3079             std::string avQueueId(avQueueIdItem->valuestring);
3080             std::string fileName = AVSessionUtils::GetFixedPathName(userId) + bundleName + "_" +
3081                 avQueueId + AVSessionUtils::GetFileSuffix();
3082             AVSessionUtils::DeleteFile(fileName);
3083             cJSON_DeleteItemFromArray(valuesArray, i);
3084         }
3085     }
3086     char* newContent = cJSON_Print(valuesArray);
3087     if (newContent == nullptr) {
3088         SLOGE("newContent print fail");
3089     } else {
3090         std::string newContentStr(newContent);
3091         if (!SaveStringToFileEx(GetAVQueueDir(userId), newContentStr)) {
3092             SLOGE("SaveStringToFile failed, filename=%{public}s", AVQUEUE_FILE_NAME);
3093         }
3094         cJSON_free(newContent);
3095     }
3096     cJSON_Delete(valuesArray);
3097 }
3098 // LCOV_EXCL_STOP
3099 
3100 // LCOV_EXCL_START
DeleteAVQueueInfoRecord(const std::string & bundleName,int32_t userId)3101 void AVSessionService::DeleteAVQueueInfoRecord(const std::string& bundleName, int32_t userId)
3102 {
3103     std::lock_guard avQueueFileLockGuard(avQueueFileLock_);
3104     if (userId <= 0) {
3105         userId = GetUsersManager().GetCurrentUserId();
3106     }
3107     if (!CheckUserDirValid(userId)) {
3108         SLOGE("DeleteAVQueueInfoRecord target user:%{public}d not valid, return", userId);
3109         return;
3110     }
3111     SLOGI("DeleteAVQueueInfoRecord, bundleName=%{public}s, userId=%{public}d", bundleName.c_str(), userId);
3112     std::string oldContent;
3113     std::string newContent;
3114     if (!LoadStringFromFileEx(GetAVQueueDir(userId), oldContent)) {
3115         SLOGE("LoadStringFromFile failed, filename=%{public}s", AVQUEUE_FILE_NAME);
3116         return;
3117     }
3118     DeleteAVQueueInfoRecordFromCJSON(oldContent, bundleName, userId);
3119 }
3120 // LCOV_EXCL_STOP
3121 
3122 
HandleOtherSessionPlaying(sptr<AVSessionItem> & session)3123 void AVSessionService::HandleOtherSessionPlaying(sptr<AVSessionItem>& session)
3124 {
3125     CHECK_AND_RETURN_LOG(session != nullptr, "No other sessions are currently playing");
3126     UpdateTopSession(session);
3127     CHECK_AND_RETURN_LOG(topSession_ != nullptr, "topSession is nullptr, update topSession fail!");
3128     bool updateOrderResult = UpdateOrder(session);
3129     CHECK_AND_RETURN_LOG(updateOrderResult, "UpdateOrder fail");
3130     if (session->GetSessionType() == "audio" || session->GetSessionType() == "video") {
3131         AVSessionService::NotifySystemUI(nullptr, true, IsCapsuleNeeded(), false);
3132     }
3133 }
3134 
GetOtherPlayingSession(int32_t userId,std::string bundleName)3135 sptr <AVSessionItem> AVSessionService::GetOtherPlayingSession(int32_t userId, std::string bundleName)
3136 {
3137     std::lock_guard frontLockGuard(sessionFrontLock_);
3138     std::shared_ptr<std::list<sptr<AVSessionItem>>> sessionListForFront = GetCurSessionListForFront(userId);
3139     CHECK_AND_RETURN_RET_LOG(sessionListForFront != nullptr, nullptr, "sessionListForFront ptr nullptr!");
3140     for (const auto& session : *sessionListForFront) {
3141         CHECK_AND_CONTINUE(session != nullptr);
3142         if (AudioAdapter::GetInstance().GetRendererRunning(session->GetUid(), session->GetPid()) &&
3143             (session->GetSessionType() != "voice_call" && session->GetSessionType() != "video_call") &&
3144             session->GetBundleName() != bundleName && !session->IsCasting()) {
3145             SLOGI("find other playing session, uid:%{public}d, pid:%{public}d, bundleName %{public}s",
3146                 session->GetUid(), session->GetPid(), session->GetBundleName().c_str());
3147             return session;
3148         }
3149     }
3150     if (!bundleName.empty()) {
3151         sptr<AVSessionItem> firstSession = sessionListForFront->front();
3152         CHECK_AND_RETURN_RET_LOG(firstSession != nullptr, nullptr, "firstSession is nullptr!");
3153         if (firstSession->IsCasting() &&
3154             firstSession->GetCastAVPlaybackState().GetState() == AVPlaybackState::PLAYBACK_STATE_PLAY) {
3155             SLOGI("find casting session, uid:%{public}d", firstSession->GetUid());
3156             return firstSession;
3157         }
3158     }
3159     return nullptr;
3160 }
3161 
HandleTopSessionRelease(int32_t userId,sptr<AVSessionItem> & sessionItem)3162 void AVSessionService::HandleTopSessionRelease(int32_t userId, sptr<AVSessionItem>& sessionItem)
3163 {
3164     if (GetUsersManager().GetTopSession(userId).GetRefPtr() == sessionItem.GetRefPtr()) {
3165         sptr<AVSessionItem> result = GetOtherPlayingSession(userId, sessionItem->GetBundleName());
3166         if (result != nullptr) {
3167             HandleOtherSessionPlaying(result);
3168         } else {
3169             UpdateTopSession(nullptr, userId);
3170             hasMediaCapsule_ = false;
3171             int32_t ret = Notification::NotificationHelper::CancelNotification(std::to_string(userId), 0);
3172             SLOGI("CancelNotification with userId:%{public}d, ret=%{public}d", userId, ret);
3173         }
3174     }
3175 }
3176 
HandleSessionRelease(std::string sessionId,bool continuePlay)3177 void AVSessionService::HandleSessionRelease(std::string sessionId, bool continuePlay)
3178 {
3179     SLOGI("HandleSessionRelease, sessionId=%{public}s", AVSessionUtils::GetAnonySessionId(sessionId).c_str());
3180     {
3181         std::lock_guard lockGuard(sessionServiceLock_);
3182         std::lock_guard frontLockGuard(sessionFrontLock_);
3183         sptr<AVSessionItem> sessionItem = GetUsersManager().GetContainerFromAll().GetSessionById(sessionId);
3184         CHECK_AND_RETURN_LOG(sessionItem != nullptr, "Session item is nullptr");
3185         int32_t userId = sessionItem->GetUserId();
3186         userId = userId < 0 ? GetUsersManager().GetCurrentUserId() : userId;
3187         SLOGD("HandleSessionRelease with userId:%{public}d", userId);
3188 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
3189         ReportSessionState(sessionItem, SessionState::STATE_RELEASE);
3190 #endif
3191         NotifySessionRelease(sessionItem->GetDescriptor());
3192         if (sessionItem->GetUid() == ancoUid) {
3193             ancoSession_ = nullptr;
3194         }
3195         sessionItem->DestroyTask(continuePlay);
3196         HandleTopSessionRelease(userId, sessionItem);
3197         if (sessionItem->GetRemoteSource() != nullptr) {
3198             int32_t ret = CancelCastAudioForClientExit(sessionItem->GetPid(), sessionItem);
3199             SLOGI("CancelCastAudioForClientExit ret is %{public}d", ret);
3200         }
3201         HISYSEVENT_ADD_LIFE_CYCLE_INFO(sessionItem->GetDescriptor().elementName_.GetBundleName(),
3202             AppManagerAdapter::GetInstance().IsAppBackground(GetCallingUid(), GetCallingPid()),
3203             sessionItem->GetDescriptor().sessionType_, false);
3204         GetUsersManager().RemoveSessionForAllUser(sessionItem->GetPid(), sessionItem->GetAbilityName());
3205         UpdateFrontSession(sessionItem, false);
3206         {
3207             std::lock_guard lockGuard(keyEventListLock_);
3208             std::shared_ptr<std::list<sptr<AVSessionItem>>> keyEventList = GetCurKeyEventSessionList();
3209             CHECK_AND_RETURN_LOG(keyEventList != nullptr, "keyEventList ptr nullptr!");
3210             auto it = std::find(keyEventList->begin(), keyEventList->end(), sessionItem);
3211             if (it != keyEventList->end()) {
3212                 SLOGI("keyEventList remove %{public}s", sessionItem->GetBundleName().c_str());
3213                 keyEventList->erase(it);
3214             }
3215         }
3216     }
3217     HandleSessionReleaseInner();
3218 }
3219 
HandleSessionReleaseInner()3220 void AVSessionService::HandleSessionReleaseInner()
3221 {
3222 #ifdef START_STOP_ON_DEMAND_ENABLE
3223     if (GetUsersManager().GetContainerFromAll().GetAllSessions().size() == 0) {
3224         PublishEvent(mediaPlayStateFalse);
3225     }
3226 #endif
3227 #ifdef CASTPLUS_CAST_ENGINE_ENABLE
3228     if ((GetUsersManager().GetContainerFromAll().GetAllSessions().size() == 0 ||
3229         (GetUsersManager().GetContainerFromAll().GetAllSessions().size() == 1 &&
3230         CheckAncoAudio())) && !is2in1_) {
3231         SLOGI("call disable cast for no session alive, after session release task");
3232         checkEnableCast(false);
3233     }
3234 #endif
3235 }
3236 
HandleControllerRelease(AVControllerItem & controller)3237 void AVSessionService::HandleControllerRelease(AVControllerItem& controller)
3238 {
3239     auto pid = controller.GetPid();
3240     std::lock_guard lockGuard(sessionServiceLock_);
3241     auto it = controllers_.find(pid);
3242     if (it == controllers_.end()) {
3243         return;
3244     }
3245     it->second.remove(&controller);
3246     if (it->second.empty()) {
3247         controllers_.erase(pid);
3248     }
3249 }
3250 
Dump(std::int32_t fd,const std::vector<std::u16string> & args)3251 std::int32_t AVSessionService::Dump(std::int32_t fd, const std::vector<std::u16string>& args)
3252 {
3253     if (fd < 0) {
3254         SLOGE("dump fd invalid");
3255         return ERR_INVALID_PARAM;
3256     }
3257 
3258     if (dumpHelper_ == nullptr) {
3259         SLOGE("dumpHelper_ is nullptr!");
3260         return ERR_INVALID_PARAM;
3261     }
3262 
3263     std::vector<std::string> argsInStr;
3264     for (const auto& arg : args) {
3265         SLOGI("Dump args: %s", Str16ToStr8(arg).c_str());
3266         argsInStr.emplace_back(Str16ToStr8(arg));
3267     }
3268 
3269     std::string result;
3270     dumpHelper_->Dump(argsInStr, result, *this);
3271     std::int32_t ret = dprintf(fd, "%s", result.c_str());
3272     if (ret < 0) {
3273         SLOGI("dprintf to dump fd failed");
3274         return ERR_INVALID_PARAM;
3275     }
3276     return AVSESSION_SUCCESS;
3277 }
3278 
GetService(const std::string & deviceId)3279 __attribute__((no_sanitize("cfi"))) std::shared_ptr<RemoteSessionCommandProcess> AVSessionService::GetService(
3280     const std::string& deviceId)
3281 {
3282     SLOGI("Enter GetService.");
3283     auto mgr = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
3284     if (mgr == nullptr) {
3285         SLOGE("GetService failed when GetSystemAbilityManager.");
3286         return nullptr;
3287     }
3288     auto object = mgr->GetSystemAbility(AVSESSION_SERVICE_ID, deviceId);
3289     if (object == nullptr) {
3290         SLOGE("GetService failed to get AVSESSION_SERVICE_ID object.");
3291         return nullptr;
3292     }
3293     std::shared_ptr<RemoteSessionCommandProcess> remoteService = std::make_shared<RemoteSessionCommandProcess>(object);
3294     return remoteService;
3295 }
3296 
IsLocalDevice(const std::string & networkId)3297 bool AVSessionService::IsLocalDevice(const std::string& networkId)
3298 {
3299     std::string localNetworkId;
3300     CHECK_AND_RETURN_RET_LOG(GetLocalNetworkId(localNetworkId) == AVSESSION_SUCCESS, AVSESSION_ERROR,
3301                              "GetLocalNetworkId error");
3302     if (networkId == localNetworkId || networkId == "LocalDevice") {
3303         SLOGI("This networkId is local device.");
3304         return true;
3305     }
3306     SLOGI("This networkId is not local device.");
3307     return false;
3308 }
3309 
GetLocalNetworkId(std::string & networkId)3310 int32_t AVSessionService::GetLocalNetworkId(std::string& networkId)
3311 {
3312     DistributedHardware::DmDeviceInfo deviceInfo;
3313     int32_t ret = DistributedHardware::DeviceManager::GetInstance().GetLocalDeviceInfo("av_session", deviceInfo);
3314     CHECK_AND_RETURN_RET_LOG(ret == 0, ret, "get local deviceInfo failed");
3315     networkId = deviceInfo.networkId;
3316     return AVSESSION_SUCCESS;
3317 }
3318 
GetTrustedDeviceName(const std::string & networkId,std::string & deviceName)3319 int32_t AVSessionService::GetTrustedDeviceName(const std::string& networkId, std::string& deviceName)
3320 {
3321     std::vector<OHOS::DistributedHardware::DmDeviceInfo> deviceList {};
3322     if (IsLocalDevice(networkId)) {
3323         deviceName = "LocalDevice";
3324         return AVSESSION_SUCCESS;
3325     }
3326     int32_t ret = GetTrustedDevicesInfo(deviceList);
3327     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "get devicesInfo failed");
3328     for (const auto& device : deviceList) {
3329         ret = strcmp(device.networkId, networkId.c_str());
3330         if (ret == 0) {
3331             deviceName = device.deviceName;
3332             return AVSESSION_SUCCESS;
3333         }
3334     }
3335     SLOGI("GetTrustedDeviceName is not find this device %{public}.6s", networkId.c_str());
3336     return AVSESSION_ERROR;
3337 }
3338 
GetTrustedDevicesInfo(std::vector<OHOS::DistributedHardware::DmDeviceInfo> & deviceList)3339 int32_t AVSessionService::GetTrustedDevicesInfo(std::vector<OHOS::DistributedHardware::DmDeviceInfo>& deviceList)
3340 {
3341     int32_t ret = DistributedHardware::DeviceManager::GetInstance().GetTrustedDeviceList("av_session", "", deviceList);
3342     CHECK_AND_RETURN_RET_LOG(ret == 0, ret, "get trusted device list failed");
3343     return AVSESSION_SUCCESS;
3344 }
3345 
SetBasicInfo(std::string & sessionInfo)3346 int32_t AVSessionService::SetBasicInfo(std::string& sessionInfo)
3347 {
3348     AVSessionBasicInfo basicInfo;
3349     basicInfo.metaDataCap_ = AVMetaData::localCapability;
3350     basicInfo.playBackStateCap_ = AVPlaybackState::localCapability;
3351     basicInfo.controlCommandCap_ = AVControlCommand::localCapability;
3352     int32_t ret = GetLocalNetworkId(basicInfo.networkId_);
3353     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, AVSESSION_ERROR, "GetLocalNetworkId failed");
3354 
3355     ret = JsonUtils::SetSessionBasicInfo(sessionInfo, basicInfo);
3356     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, AVSESSION_ERROR, "SetDeviceId failed");
3357     return AVSESSION_SUCCESS;
3358 }
3359 
SetDeviceInfo(const std::vector<AudioStandard::AudioDeviceDescriptor> & castAudioDescriptors,sptr<AVSessionItem> & session)3360 void AVSessionService::SetDeviceInfo(const std::vector<AudioStandard::AudioDeviceDescriptor>& castAudioDescriptors,
3361     sptr <AVSessionItem>& session)
3362 {
3363     CHECK_AND_RETURN_LOG(session != nullptr && castAudioDescriptors.size() > 0, "invalid argument");
3364 
3365     OutputDeviceInfo outputDeviceInfo;
3366     outputDeviceInfo.deviceInfos_.clear();
3367     int32_t castCategory = AVCastCategory::CATEGORY_LOCAL;
3368     if (!IsLocalDevice(castAudioDescriptors[0].networkId_)) {
3369         castCategory = AVCastCategory::CATEGORY_REMOTE;
3370     }
3371     for (const auto &audioDescriptor : castAudioDescriptors) {
3372         DeviceInfo deviceInfo;
3373         deviceInfo.castCategory_ = castCategory;
3374         deviceInfo.deviceId_ = std::to_string(audioDescriptor.deviceId_);
3375         deviceInfo.deviceName_ = audioDescriptor.deviceName_;
3376         SLOGI("SetDeviceInfo the deviceName is %{public}s", audioDescriptor.deviceName_.c_str());
3377         outputDeviceInfo.deviceInfos_.emplace_back(deviceInfo);
3378     }
3379     session->SetOutputDevice(outputDeviceInfo);
3380 }
3381 
GetAudioDescriptorByDeviceId(const std::vector<std::shared_ptr<AudioStandard::AudioDeviceDescriptor>> & descriptors,const std::string & deviceId,AudioStandard::AudioDeviceDescriptor & audioDescriptor)3382 bool AVSessionService::GetAudioDescriptorByDeviceId(
3383     const std::vector<std::shared_ptr<AudioStandard::AudioDeviceDescriptor>>& descriptors,
3384     const std::string& deviceId,
3385     AudioStandard::AudioDeviceDescriptor& audioDescriptor)
3386 {
3387     for (const auto& descriptor : descriptors) {
3388         if (std::to_string(descriptor->deviceId_) == deviceId) {
3389             audioDescriptor = *descriptor;
3390             return true;
3391         }
3392     }
3393     SLOGI("GetAudioDescriptorByDeviceId deviceId:%{public}s is not found in all audio descriptors", deviceId.c_str());
3394     return false;
3395 }
3396 
GetDeviceInfo(const sptr<AVSessionItem> & session,const std::vector<AudioStandard::AudioDeviceDescriptor> & descriptors,std::vector<AudioStandard::AudioDeviceDescriptor> & castSinkDescriptors,std::vector<AudioStandard::AudioDeviceDescriptor> & cancelSinkDescriptors)3397 void AVSessionService::GetDeviceInfo(const sptr <AVSessionItem>& session,
3398     const std::vector<AudioStandard::AudioDeviceDescriptor>& descriptors,
3399     std::vector<AudioStandard::AudioDeviceDescriptor>& castSinkDescriptors,
3400     std::vector<AudioStandard::AudioDeviceDescriptor>& cancelSinkDescriptors)
3401 {
3402     if (descriptors.size() != 1) {
3403         SLOGI("descriptor size is %{public}d, not support", static_cast<int32_t>(descriptors.size()));
3404         return;
3405     }
3406     castSinkDescriptors.push_back(descriptors[0]);
3407     OutputDeviceInfo tempOutputDeviceInfo;
3408     session->GetOutputDevice(tempOutputDeviceInfo);
3409     // If not in remote, return directly
3410     if (tempOutputDeviceInfo.deviceInfos_.size() == 0 || tempOutputDeviceInfo.deviceInfos_[0].castCategory_ == 1) {
3411         SLOGI("castCategory is %{public}d, no need to cancel", tempOutputDeviceInfo.deviceInfos_[0].castCategory_);
3412         return;
3413     }
3414     int32_t ret = GetAudioDescriptor(session->GetDescriptor().outputDeviceInfo_.deviceInfos_[0].deviceId_,
3415                                      cancelSinkDescriptors);
3416     CHECK_AND_RETURN_LOG(ret == AVSESSION_SUCCESS, "get cancelSinkDescriptors failed");
3417 }
3418 
SelectOutputDevice(const int32_t uid,const AudioDeviceDescriptor & descriptor)3419 int32_t AVSessionService::SelectOutputDevice(const int32_t uid, const AudioDeviceDescriptor& descriptor)
3420 {
3421     sptr <AudioStandard::AudioRendererFilter> audioFilter = new(std::nothrow) AudioRendererFilter();
3422     CHECK_AND_RETURN_RET_LOG(audioFilter != nullptr, ERR_NO_MEMORY, "new AudioRendererFilter failed");
3423     audioFilter->uid = uid;
3424     audioFilter->rendererInfo.contentType = ContentType::CONTENT_TYPE_MUSIC;
3425     audioFilter->rendererInfo.streamUsage = StreamUsage::STREAM_USAGE_MEDIA;
3426 
3427     std::vector<std::shared_ptr<AudioDeviceDescriptor>> audioDescriptor;
3428     auto audioDeviceDescriptor = std::make_shared<AudioDeviceDescriptor>(descriptor);
3429     CHECK_AND_RETURN_RET_LOG(audioDeviceDescriptor != nullptr, ERR_NO_MEMORY, "audioDeviceDescriptor is nullptr");
3430     audioDescriptor.push_back(audioDeviceDescriptor);
3431     SLOGI("select the device %{public}s role is %{public}d, networkId is %{public}.6s",
3432         descriptor.deviceName_.c_str(), static_cast<int32_t>(descriptor.deviceRole_), descriptor.networkId_.c_str());
3433 
3434     AudioSystemManager *audioSystemMgr = AudioSystemManager::GetInstance();
3435     CHECK_AND_RETURN_RET_LOG(audioSystemMgr != nullptr, AVSESSION_ERROR, "get AudioSystemManager instance failed");
3436     int32_t ret = audioSystemMgr->SelectOutputDevice(audioFilter, audioDescriptor);
3437     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, AVSESSION_ERROR, "SelectOutputDevice failed");
3438 
3439     return AVSESSION_SUCCESS;
3440 }
3441 
CastAudio(const SessionToken & token,const std::vector<AudioStandard::AudioDeviceDescriptor> & sinkAudioDescriptors)3442 int32_t AVSessionService::CastAudio(const SessionToken& token,
3443                                     const std::vector<AudioStandard::AudioDeviceDescriptor>& sinkAudioDescriptors)
3444 {
3445     std::string sourceSessionInfo;
3446     int32_t ret = SetBasicInfo(sourceSessionInfo);
3447     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "SetBasicInfo failed");
3448     sptr<AVSessionItem> session = GetContainer().GetSessionById(token.sessionId);
3449     CHECK_AND_RETURN_RET_LOG(session != nullptr, ERR_SESSION_NOT_EXIST, "session %{public}s not exist",
3450                              AVSessionUtils::GetAnonySessionId(token.sessionId).c_str());
3451     ret = JsonUtils::SetSessionDescriptor(sourceSessionInfo, session->GetDescriptor());
3452     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "SetDescriptorInfo failed");
3453     ret = CastAudioProcess(sinkAudioDescriptors, sourceSessionInfo, session);
3454     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CastAudioProcess failed");
3455     return AVSESSION_SUCCESS;
3456 }
3457 
CastAudioProcess(const std::vector<AudioStandard::AudioDeviceDescriptor> & descriptors,const std::string & sourceSessionInfo,sptr<AVSessionItem> & session)3458 int32_t AVSessionService::CastAudioProcess(const std::vector<AudioStandard::AudioDeviceDescriptor>& descriptors,
3459                                            const std::string& sourceSessionInfo,
3460                                            sptr <AVSessionItem>& session)
3461 {
3462     std::vector<AudioDeviceDescriptor> castSinkDescriptors;
3463     std::vector<AudioDeviceDescriptor> cancelSinkDescriptors;
3464     GetDeviceInfo(session, descriptors, castSinkDescriptors, cancelSinkDescriptors);
3465 
3466     if (cancelSinkDescriptors.size() > 0) {
3467         int32_t ret = CancelCastAudioInner(cancelSinkDescriptors, sourceSessionInfo, session);
3468         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CancelCastAudioInner failed");
3469     }
3470 
3471     if (castSinkDescriptors.size() > 0) {
3472         int32_t ret = CastAudioInner(castSinkDescriptors, sourceSessionInfo, session);
3473         if (ret != AVSESSION_SUCCESS) {
3474             SLOGE("CastAudioInner failed, try cancel it. ret is %{public}d",
3475                 CancelCastAudioInner(castSinkDescriptors, sourceSessionInfo, session));
3476             return ret;
3477         }
3478     }
3479 
3480     SetDeviceInfo(descriptors, session);
3481     return AVSESSION_SUCCESS;
3482 }
3483 
CastAudioInner(const std::vector<AudioStandard::AudioDeviceDescriptor> & sinkAudioDescriptors,const std::string & sourceSessionInfo,const sptr<AVSessionItem> & session)3484 int32_t AVSessionService::CastAudioInner(const std::vector<AudioStandard::AudioDeviceDescriptor>& sinkAudioDescriptors,
3485                                          const std::string& sourceSessionInfo,
3486                                          const sptr <AVSessionItem>& session)
3487 {
3488     CHECK_AND_RETURN_RET_LOG(sinkAudioDescriptors.size() > 0, AVSESSION_ERROR, "sinkDescriptors is empty");
3489     std::string sourceDevice;
3490     CHECK_AND_RETURN_RET_LOG(GetLocalNetworkId(sourceDevice) == AVSESSION_SUCCESS, AVSESSION_ERROR,
3491                              "GetLocalNetworkId failed");
3492     SLOGI("networkId_: %{public}.6s, role %{public}d", sinkAudioDescriptors[0].networkId_.c_str(),
3493           static_cast<int32_t>(sinkAudioDescriptors[0].deviceRole_));
3494     if (IsLocalDevice(sinkAudioDescriptors[0].networkId_)) {
3495         int32_t ret = SelectOutputDevice(session->GetUid(), sinkAudioDescriptors[0]);
3496         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "selectOutputDevice failed");
3497         return AVSESSION_SUCCESS;
3498     }
3499 
3500     SLOGI("sinkAudioDescriptors size is %{public}d", static_cast<int32_t>(sinkAudioDescriptors.size()));
3501     for (const auto& sinkAudioDescriptor : sinkAudioDescriptors) {
3502         std::string sinkSessionInfo;
3503         auto service = GetService(sinkAudioDescriptor.networkId_);
3504         CHECK_AND_RETURN_RET_LOG(service != nullptr, AVSESSION_ERROR, "GetService %{public}s failed",
3505                                  sinkAudioDescriptor.networkId_.c_str());
3506         int32_t ret = service->ProcessCastAudioCommand(RemoteServiceCommand::COMMAND_CAST_AUDIO, sourceSessionInfo,
3507                                                        sinkSessionInfo);
3508         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "ProcessCastAudioCommand failed");
3509         std::string sinkCapability;
3510         ret = JsonUtils::GetAllCapability(sinkSessionInfo, sinkCapability);
3511         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetAllCapability failed");
3512         ret = session->CastAudioToRemote(sourceDevice, sinkAudioDescriptor.networkId_, sinkCapability);
3513         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CastAudioToRemote failed");
3514         HISYSEVENT_BEHAVIOR("SESSION_CAST",
3515             "BUNDLE_NAME", session->GetDescriptor().elementName_.GetBundleName(),
3516             "MODULE_NAME", session->GetDescriptor().elementName_.GetModuleName(),
3517             "ABILITY_NAME", session->GetDescriptor().elementName_.GetAbilityName(),
3518             "SESSION_PID", session->GetDescriptor().pid_,
3519             "SESSION_UID", session->GetDescriptor().uid_,
3520             "SESSION_ID", session->GetDescriptor().sessionId_,
3521             "SESSION_TAG", session->GetDescriptor().sessionTag_,
3522             "SESSION_TYPE", session->GetDescriptor().sessionType_,
3523             "CAST_TYPE", 0,
3524             "DEST_DEVICE_TYPE", sinkAudioDescriptor.deviceType_,
3525             "DEST_DEVICE_NAME", sinkAudioDescriptor.deviceName_.c_str(),
3526             "DEST_DEVICE_ID", sinkAudioDescriptor.deviceId_,
3527             "DETAILED_MSG", "avsession service cast audio");
3528         ret = SelectOutputDevice(session->GetUid(), sinkAudioDescriptor);
3529         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "selectOutputDevice failed");
3530     }
3531     SLOGI("success");
3532     return AVSESSION_SUCCESS;
3533 }
3534 
CancelCastAudioInner(const std::vector<AudioStandard::AudioDeviceDescriptor> & sinkDevices,const std::string & sourceSessionInfo,const sptr<AVSessionItem> & session)3535 int32_t AVSessionService::CancelCastAudioInner(const std::vector<AudioStandard::AudioDeviceDescriptor>& sinkDevices,
3536                                                const std::string& sourceSessionInfo,
3537                                                const sptr <AVSessionItem>& session)
3538 {
3539     SLOGI("cancel sinkDevices size is %{public}d", static_cast<int32_t>(sinkDevices.size()));
3540     CHECK_AND_RETURN_RET_LOG(!sinkDevices.empty(), AVSESSION_ERROR, "sinkDevices is empty");
3541     for (const auto& sinkDevice : sinkDevices) {
3542         if (IsLocalDevice(sinkDevice.networkId_)) {
3543             SLOGI("cancel Local device %{public}.6s", sinkDevice.networkId_.c_str());
3544             continue;
3545         }
3546         std::string sinkSessionInfo;
3547         SLOGI("cancel sinkDevices sinkDevice.networkId_ is %{public}.6s", sinkDevice.networkId_.c_str());
3548         auto service = GetService(sinkDevice.networkId_);
3549         CHECK_AND_RETURN_RET_LOG(service != nullptr, AVSESSION_ERROR, "GetService %{public}s failed",
3550                                  sinkDevice.networkId_.c_str());
3551         int32_t ret = service->ProcessCastAudioCommand(RemoteServiceCommand::COMMAND_CANCEL_CAST_AUDIO,
3552                                                        sourceSessionInfo, sinkSessionInfo);
3553         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "ProcessCastAudioCommand failed");
3554         ret = session->SourceCancelCastAudio(sinkDevice.networkId_);
3555         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "SourceCancelCastAudio failed");
3556     }
3557     return AVSESSION_SUCCESS;
3558 }
3559 
CastAudioForNewSession(const sptr<AVSessionItem> & session)3560 int32_t AVSessionService::CastAudioForNewSession(const sptr<AVSessionItem>& session)
3561 {
3562     SLOGI("new sessionId is %{public}s", AVSessionUtils::GetAnonySessionId(session->GetSessionId()).c_str());
3563     SessionToken token;
3564     token.sessionId = session->GetSessionId();
3565     token.pid = session->GetPid();
3566     token.uid = session->GetUid();
3567 
3568     int32_t ret = AVSESSION_SUCCESS;
3569     std::vector<AudioStandard::AudioDeviceDescriptor> castSinkDevices;
3570     {
3571         std::lock_guard lockGuard(outputDeviceIdLock_);
3572         ret = GetAudioDescriptor(outputDeviceId_, castSinkDevices);
3573         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetAudioDescriptor failed");
3574     }
3575 
3576     ret = CastAudio(token, castSinkDevices);
3577     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CastAudio error, session Id is %{public}s",
3578                              AVSessionUtils::GetAnonySessionId(token.sessionId).c_str());
3579 
3580     SLOGI("success");
3581     return AVSESSION_SUCCESS;
3582 }
3583 
CastAudioForAll(const std::vector<AudioStandard::AudioDeviceDescriptor> & sinkAudioDescriptors)3584 int32_t AVSessionService::CastAudioForAll(const std::vector<AudioStandard::AudioDeviceDescriptor>& sinkAudioDescriptors)
3585 {
3586     CHECK_AND_RETURN_RET_LOG(sinkAudioDescriptors.size() > 0, ERR_INVALID_PARAM, "sinkAudioDescriptors is empty");
3587     {
3588         std::lock_guard lockGuard(isAllSessionCastLock_);
3589         isAllSessionCast_ = false;
3590         if (!IsLocalDevice(sinkAudioDescriptors[0].networkId_)) {
3591             isAllSessionCast_ = true;
3592         }
3593     }
3594     for (const auto& session : GetContainer().GetAllSessions()) {
3595         SessionToken token;
3596         token.sessionId = session->GetSessionId();
3597         token.pid = session->GetPid();
3598         token.uid = session->GetUid();
3599         SLOGI("cast session %{public}s", AVSessionUtils::GetAnonySessionId(token.sessionId).c_str());
3600         int32_t ret = CastAudio(token, sinkAudioDescriptors);
3601         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CastAudio session %{public}s failed",
3602                                  AVSessionUtils::GetAnonySessionId(token.sessionId).c_str());
3603         {
3604             std::lock_guard lockGuard(outputDeviceIdLock_);
3605             outputDeviceId_ = session->GetDescriptor().outputDeviceInfo_.deviceInfos_[0].deviceId_;
3606         }
3607     }
3608 
3609     return AVSESSION_SUCCESS;
3610 }
3611 
ProcessCastAudioCommand(const RemoteServiceCommand command,const std::string & input,std::string & output)3612 int32_t AVSessionService::ProcessCastAudioCommand(const RemoteServiceCommand command, const std::string& input,
3613                                                   std::string& output)
3614 {
3615     SLOGI("ProcessCastAudioCommand command is %{public}d", static_cast<int32_t>(command));
3616     CHECK_AND_RETURN_RET_LOG(command > COMMAND_INVALID && command < COMMAND_MAX, AVSESSION_ERROR, "invalid command");
3617     if (command == COMMAND_CAST_AUDIO) {
3618         int ret = RemoteCastAudioInner(input, output);
3619         CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "RemoteCastAudioInner error");
3620         return AVSESSION_SUCCESS;
3621     }
3622 
3623     int ret = RemoteCancelCastAudioInner(input);
3624     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "RemoteCancelCastAudioInner error");
3625     return AVSESSION_SUCCESS;
3626 }
3627 
RemoteCastAudioInner(const std::string & sourceSessionInfo,std::string & sinkSessionInfo)3628 int32_t AVSessionService::RemoteCastAudioInner(const std::string& sourceSessionInfo, std::string& sinkSessionInfo)
3629 {
3630     SLOGI("sourceInfo : %{public}s", sourceSessionInfo.c_str());
3631     AVSessionDescriptor sourceDescriptor;
3632     int32_t ret = JsonUtils::GetSessionDescriptor(sourceSessionInfo, sourceDescriptor);
3633     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetSessionDescriptor failed");
3634 
3635     ret = SetBasicInfo(sinkSessionInfo);
3636     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, AVSESSION_ERROR, "SetBasicInfo failed");
3637     AVSessionBasicInfo sinkDeviceInfo;
3638     ret = JsonUtils::GetSessionBasicInfo(sinkSessionInfo, sinkDeviceInfo);
3639     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetBasicInfo failed");
3640 
3641     sptr <AVSessionItem> session;
3642     auto res = CreateSessionInner(sourceDescriptor.sessionTag_, sourceDescriptor.sessionType_,
3643                                   sourceDescriptor.isThirdPartyApp_, sourceDescriptor.elementName_, session);
3644     CHECK_AND_RETURN_RET_LOG(res == AVSESSION_SUCCESS, res, "CreateSession failed");
3645 
3646     {
3647         std::lock_guard lockGuard(castAudioSessionMapLock_);
3648         castAudioSessionMap_[sourceDescriptor.sessionId_] = session->GetSessionId();
3649     }
3650 
3651     AVSessionBasicInfo sourceDeviceInfo;
3652     ret = JsonUtils::GetSessionBasicInfo(sourceSessionInfo, sourceDeviceInfo);
3653     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetBasicInfo failed");
3654     std::string sourceCapability;
3655     ret = JsonUtils::GetAllCapability(sourceSessionInfo, sourceCapability);
3656     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetAllCapability failed");
3657     ret = session->CastAudioFromRemote(sourceDescriptor.sessionId_, sourceDeviceInfo.networkId_,
3658                                        sinkDeviceInfo.networkId_, sourceCapability);
3659     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CastAudioFromRemote failed");
3660     JsonUtils::SetSessionDescriptor(sinkSessionInfo, session->GetDescriptor());
3661     return AVSESSION_SUCCESS;
3662 }
3663 
RemoteCancelCastAudioInner(const std::string & sessionInfo)3664 int32_t AVSessionService::RemoteCancelCastAudioInner(const std::string& sessionInfo)
3665 {
3666     SLOGI("sessionInfo is %{public}s", sessionInfo.c_str());
3667     AVSessionBasicInfo sourceDeviceInfo;
3668     int32_t ret = JsonUtils::GetSessionBasicInfo(sessionInfo, sourceDeviceInfo);
3669     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetBasicInfo failed");
3670     AVSessionDescriptor sourceDescriptor;
3671     ret = JsonUtils::GetSessionDescriptor(sessionInfo, sourceDescriptor);
3672     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetSessionDescriptor failed");
3673 
3674     std::lock_guard lockGuard(castAudioSessionMapLock_);
3675     auto iter = castAudioSessionMap_.find(sourceDescriptor.sessionId_);
3676     CHECK_AND_RETURN_RET_LOG(iter != castAudioSessionMap_.end(), AVSESSION_ERROR, "no source session %{public}s",
3677                              AVSessionUtils::GetAnonySessionId(sourceDescriptor.sessionId_).c_str());
3678     auto session = GetContainer().GetSessionById(iter->second);
3679     CHECK_AND_RETURN_RET_LOG(session != nullptr, AVSESSION_ERROR, "no sink session %{public}s",
3680         AVSessionUtils::GetAnonySessionId(iter->second).c_str());
3681 
3682     ret = session->SinkCancelCastAudio();
3683     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "SinkCancelCastAudio failed");
3684     HandleSessionRelease(session->GetSessionId());
3685     castAudioSessionMap_.erase(sourceDescriptor.sessionId_);
3686     SLOGI("cancel source session %{public}s success",
3687         AVSessionUtils::GetAnonySessionId(sourceDescriptor.sessionId_).c_str());
3688     return AVSESSION_SUCCESS;
3689 }
3690 
CancelCastAudioForClientExit(pid_t pid,const sptr<AVSessionItem> & session)3691 int32_t AVSessionService::CancelCastAudioForClientExit(pid_t pid, const sptr<AVSessionItem>& session)
3692 {
3693     CHECK_AND_RETURN_RET_LOG(session != nullptr, AVSESSION_ERROR, "session is nullptr");
3694     SLOGI("pid is %{public}d, sessionId is %{public}s", static_cast<int32_t>(pid),
3695         AVSessionUtils::GetAnonySessionId(session->GetSessionId()).c_str());
3696     std::string sourceSessionInfo;
3697     int32_t ret = SetBasicInfo(sourceSessionInfo);
3698     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "SetBasicInfo failed");
3699     ret = JsonUtils::SetSessionDescriptor(sourceSessionInfo, session->GetDescriptor());
3700     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "SetDescriptorInfo failed");
3701 
3702     std::vector<AudioStandard::AudioDeviceDescriptor> cancelSinkDevices;
3703     ret = GetAudioDescriptor(session->GetDescriptor().outputDeviceInfo_.deviceInfos_[0].deviceId_, cancelSinkDevices);
3704     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "GetAudioDescriptor failed");
3705 
3706     ret = CancelCastAudioInner(cancelSinkDevices, sourceSessionInfo, session);
3707     CHECK_AND_RETURN_RET_LOG(ret == AVSESSION_SUCCESS, ret, "CancelCastAudioInner failed");
3708     return AVSESSION_SUCCESS;
3709 }
3710 
GetAudioDescriptor(const std::string deviceId,std::vector<AudioStandard::AudioDeviceDescriptor> & audioDeviceDescriptors)3711 int32_t AVSessionService::GetAudioDescriptor(const std::string deviceId,
3712                                              std::vector<AudioStandard::AudioDeviceDescriptor>& audioDeviceDescriptors)
3713 {
3714     auto audioDescriptors = AudioSystemManager::GetInstance()->GetDevices(ALL_L_D_DEVICES_FLAG);
3715     AudioDeviceDescriptor audioDescriptor;
3716     if (GetAudioDescriptorByDeviceId(audioDescriptors, deviceId, audioDescriptor)) {
3717         audioDeviceDescriptors.push_back(audioDescriptor);
3718         SLOGI("get audio networkId_ is %{public}.6s", audioDescriptor.networkId_.c_str());
3719         return AVSESSION_SUCCESS;
3720     }
3721     SLOGI("can not get deviceId %{public}s info", deviceId.c_str());
3722     return AVSESSION_ERROR;
3723 }
3724 
ClearSessionForClientDiedNoLock(pid_t pid,bool continuePlay)3725 void AVSessionService::ClearSessionForClientDiedNoLock(pid_t pid, bool continuePlay)
3726 {
3727     SLOGI("clear session in ");
3728     auto sessions = GetUsersManager().GetContainerFromAll().GetSessionsByPid(pid);
3729     for (const auto& session : sessions) {
3730         SLOGI("check session release task for id %{public}s",
3731             AVSessionUtils::GetAnonySessionId(session->GetSessionId()).c_str());
3732         HandleSessionRelease(session->GetSessionId(), continuePlay);
3733     }
3734 }
3735 
ClearControllerForClientDiedNoLock(pid_t pid)3736 void AVSessionService::ClearControllerForClientDiedNoLock(pid_t pid)
3737 {
3738     auto it = controllers_.find(pid);
3739     CHECK_AND_RETURN_LOG(it != controllers_.end(), "no find controller");
3740     auto controllers = std::move(it->second);
3741     SLOGI("remove controllers size=%{public}d", static_cast<int>(controllers.size()));
3742     if (!controllers.empty()) {
3743         for (const auto& controller : controllers) {
3744             controller->DestroyWithoutReply();
3745         }
3746     }
3747     it = controllers_.find(pid);
3748     CHECK_AND_RETURN_LOG(it != controllers_.end(), "no find controller");
3749     controllers_.erase(pid);
3750 }
3751 
ClientDeathRecipient(const std::function<void ()> & callback)3752 ClientDeathRecipient::ClientDeathRecipient(const std::function<void()>& callback)
3753     : callback_(callback)
3754 {
3755     SLOGD("construct");
3756 }
3757 
OnRemoteDied(const wptr<IRemoteObject> & object)3758 void ClientDeathRecipient::OnRemoteDied(const wptr<IRemoteObject>& object)
3759 {
3760     if (callback_) {
3761         callback_();
3762     }
3763 }
3764 
CheckUserDirValid(int32_t userId)3765 bool AVSessionService::CheckUserDirValid(int32_t userId)
3766 {
3767     std::string filePath = GetUsersManager().GetDirForCurrentUser(userId);
3768     filesystem::path directory(filePath);
3769     std::error_code errCode;
3770     if (!filesystem::exists(directory, errCode)) {
3771         SLOGE("check user dir not exsit %{public}s for user %{public}d, errCode %{public}d",
3772             filePath.c_str(), userId, static_cast<int>(errCode.value()));
3773         return false;
3774     }
3775     return true;
3776 }
3777 
CheckAndCreateDir(const string & filePath)3778 bool AVSessionService::CheckAndCreateDir(const string& filePath)
3779 {
3780     CHECK_AND_RETURN_RET_LOG(CheckUserDirValid(), false, "check userDir err!");
3781     filesystem::path directory = filesystem::path(filePath).parent_path();
3782     if (!filesystem::exists(directory)) {
3783         SLOGI("check file not exist:%{public}s", filePath.c_str());
3784         return false;
3785     }
3786     return true;
3787 }
3788 
FillFileWithEmptyContentEx(ofstream & fileWrite)3789 bool AVSessionService::FillFileWithEmptyContentEx(ofstream& fileWrite)
3790 {
3791     cJSON* emptyValueArray = cJSON_CreateArray();
3792     CHECK_AND_RETURN_RET_LOG(emptyValueArray != nullptr, false, "emptyValueArray create nullptr");
3793     if (cJSON_IsInvalid(emptyValueArray) || !cJSON_IsArray(emptyValueArray)) {
3794         SLOGE("create emptyValueArray invalid");
3795         cJSON_Delete(emptyValueArray);
3796         return false;
3797     }
3798     char* emptyContent = cJSON_Print(emptyValueArray);
3799     if (emptyContent == nullptr) {
3800         SLOGE("newValueArray print fail nullptr");
3801         cJSON_Delete(emptyValueArray);
3802         return false;
3803     }
3804     std::string emptyContentStr(emptyContent);
3805     SLOGD("LoadStringFromFileEx::Dump json object finished");
3806     fileWrite.write(emptyContentStr.c_str(), emptyContentStr.length());
3807     if (fileWrite.fail()) {
3808         SLOGE("file empty init json fail !");
3809         cJSON_free(emptyContent);
3810         cJSON_Delete(emptyValueArray);
3811         return false;
3812     }
3813     cJSON_free(emptyContent);
3814     cJSON_Delete(emptyValueArray);
3815     return true;
3816 }
3817 
LoadStringFromFileEx(const string & filePath,string & content)3818 bool AVSessionService::LoadStringFromFileEx(const string& filePath, string& content)
3819 {
3820     SLOGD("file load in for path: %{public}s", filePath.c_str());
3821     CheckAndCreateDir(filePath);
3822     ifstream file(filePath.c_str());
3823     if (!file.is_open()) {
3824         SLOGD("file not open! try open first ! ");
3825         file.open(filePath.c_str(), ios::out | ios::app);
3826         if (!file.is_open()) {
3827             SLOGE("open file again fail !");
3828             return false;
3829         }
3830     }
3831     file.seekg(0, ios::end);
3832     const long fileLength = file.tellg();
3833     SLOGD("get file length(%{public}ld)!", fileLength);
3834     if (fileLength > maxFileLength) {
3835         SLOGE("invalid file length(%{public}ld)!", fileLength);
3836         return false;
3837     }
3838     if (fileLength <= 0) {
3839         SLOGD("file new create empty ! try set init json ");
3840         ofstream fileWrite;
3841         fileWrite.open(filePath.c_str(), ios::out | ios::trunc);
3842         if (!fileWrite.is_open()) {
3843             SLOGE("open file in create new failed!");
3844             file.close();
3845             return false;
3846         }
3847         if (!FillFileWithEmptyContentEx(fileWrite)) {
3848             SLOGE("file empty init json fail !");
3849             file.close();
3850             fileWrite.close();
3851             return false;
3852         }
3853         fileWrite.close();
3854     }
3855     content.clear();
3856     file.seekg(0, ios::beg);
3857     copy(istreambuf_iterator<char>(file), istreambuf_iterator<char>(), back_inserter(content));
3858     file.close();
3859     return CheckStringAndCleanFile(filePath);
3860 }
3861 
SaveStringToFileEx(const std::string & filePath,const std::string & content)3862 bool AVSessionService::SaveStringToFileEx(const std::string& filePath, const std::string& content)
3863 {
3864     SLOGI("file save in for path:%{public}s, content:%{public}s", filePath.c_str(), content.c_str());
3865     cJSON* checkValuesItem = cJSON_Parse(content.c_str());
3866     CHECK_AND_RETURN_RET_LOG(checkValuesItem != nullptr, false, "cjson parse nullptr");
3867     if (cJSON_IsInvalid(checkValuesItem)) {
3868         SLOGE("cjson parse invalid");
3869         cJSON_Delete(checkValuesItem);
3870         return false;
3871     }
3872     cJSON_Delete(checkValuesItem);
3873 
3874     ofstream file;
3875     file.open(filePath.c_str(), ios::out | ios::trunc);
3876     if (!file.is_open()) {
3877         SLOGE("open file in save failed!");
3878         return false;
3879     }
3880     if (content.empty()) {
3881         SLOGE("write content is empty, no need to do write!");
3882         file.close();
3883         return true;
3884     }
3885     file.write(content.c_str(), content.length());
3886     if (file.fail()) {
3887         SLOGE("write content to file failed!");
3888         file.close();
3889         return false;
3890     }
3891     file.close();
3892     return CheckStringAndCleanFile(filePath);
3893 }
3894 
CheckStringAndCleanFile(const std::string & filePath)3895 bool AVSessionService::CheckStringAndCleanFile(const std::string& filePath)
3896 {
3897     SLOGD("file check for path:%{public}s", filePath.c_str());
3898     string content {};
3899     ifstream fileRead(filePath.c_str());
3900     if (!fileRead.is_open()) {
3901         SLOGD("file not open! try open first ! ");
3902         fileRead.open(filePath.c_str(), ios::app);
3903         if (!fileRead.is_open()) {
3904             SLOGE("open file again fail !");
3905             return false;
3906         }
3907     }
3908     content.clear();
3909     fileRead.seekg(0, ios::beg);
3910     copy(istreambuf_iterator<char>(fileRead), istreambuf_iterator<char>(), back_inserter(content));
3911     SLOGD("check content pre clean it: %{public}s", content.c_str());
3912     cJSON* checkValuesItem = cJSON_Parse(content.c_str());
3913     bool isJsonDiscarded = false;
3914     if (checkValuesItem == nullptr) {
3915         isJsonDiscarded = true;
3916     } else {
3917         if (cJSON_IsInvalid(checkValuesItem)) {
3918             isJsonDiscarded = true;
3919             cJSON_Delete(checkValuesItem);
3920         }
3921     }
3922     if (isJsonDiscarded) {
3923         SLOGE("check content discarded! content %{public}s", content.c_str());
3924         ofstream fileWrite;
3925         fileWrite.open(filePath.c_str(), ios::out | ios::trunc);
3926         if (!fileWrite.is_open()) {
3927             SLOGE("open file in create new failed!");
3928             fileRead.close();
3929             return false;
3930         }
3931         if (!FillFileWithEmptyContentEx(fileWrite)) {
3932             SLOGE("file empty init json fail! content %{public}s", content.c_str());
3933             fileRead.close();
3934             fileWrite.close();
3935             return false;
3936         }
3937         fileWrite.close();
3938     }
3939     fileRead.close();
3940     return true;
3941 }
3942 
CreateWantAgent(const AVSessionDescriptor * histroyDescriptor)3943 std::shared_ptr<AbilityRuntime::WantAgent::WantAgent> AVSessionService::CreateWantAgent(
3944     const AVSessionDescriptor* histroyDescriptor)
3945 {
3946     if (histroyDescriptor == nullptr && topSession_ == nullptr) {
3947         SLOGE("CreateWantAgent error, histroyDescriptor and topSession_ null");
3948         return nullptr;
3949     }
3950     std::vector<AbilityRuntime::WantAgent::WantAgentConstant::Flags> flags;
3951     flags.push_back(AbilityRuntime::WantAgent::WantAgentConstant::Flags::UPDATE_PRESENT_FLAG);
3952     std::vector<std::shared_ptr<AAFwk::Want>> wants;
3953     std::shared_ptr<AAFwk::Want> want = std::make_shared<AAFwk::Want>();
3954     std::shared_ptr<AbilityRuntime::WantAgent::WantAgent> launWantAgent;
3955     string bundleName = DEFAULT_BUNDLE_NAME;
3956     string abilityName = DEFAULT_ABILITY_NAME;
3957     auto uid = -1;
3958     auto isCustomer = false;
3959     if (topSession_ != nullptr) {
3960         bundleName = topSession_->GetBundleName();
3961         abilityName = topSession_->GetAbilityName();
3962         uid = topSession_->GetUid();
3963         launWantAgent = std::make_shared<AbilityRuntime::WantAgent::WantAgent>(topSession_->GetLaunchAbility());
3964         auto res = AbilityRuntime::WantAgent::WantAgentHelper::GetWant(launWantAgent, want);
3965         isCustomer = (res == AVSESSION_SUCCESS) && (bundleName == want->GetElement().GetBundleName());
3966         SLOGI("CreateWantAgent GetWant res=%{public}d", res);
3967     }
3968     if (histroyDescriptor != nullptr) {
3969         SLOGI("CreateWantAgent with historyDescriptor");
3970         bundleName = histroyDescriptor->elementName_.GetBundleName();
3971         abilityName = histroyDescriptor->elementName_.GetAbilityName();
3972         uid = histroyDescriptor->uid_;
3973         isCustomer = false;
3974     }
3975     SLOGI("CreateWantAgent bundleName %{public}s, abilityName %{public}s, isCustomer %{public}d",
3976         bundleName.c_str(), abilityName.c_str(), isCustomer);
3977     if (!isCustomer) {
3978         AppExecFwk::ElementName element("", bundleName, abilityName);
3979         want->SetElement(element);
3980     }
3981     wants.push_back(want);
3982     AbilityRuntime::WantAgent::WantAgentInfo wantAgentInfo(
3983         0,
3984         AbilityRuntime::WantAgent::WantAgentConstant::OperationType::START_ABILITY,
3985         flags,
3986         wants,
3987         nullptr
3988     );
3989     return AbilityRuntime::WantAgent::WantAgentHelper::GetWantAgent(wantAgentInfo, uid);
3990 }
3991 
RemoveExpired(std::list<std::chrono::system_clock::time_point> & list,const std::chrono::system_clock::time_point & now,int32_t time)3992 void AVSessionService::RemoveExpired(std::list<std::chrono::system_clock::time_point> &list,
3993     const std::chrono::system_clock::time_point &now, int32_t time)
3994 {
3995     auto iter = list.begin();
3996     while (iter != list.end()) {
3997         auto duration = now - static_cast<std::chrono::system_clock::time_point>(*iter);
3998         int32_t durationInSeconds = std::chrono::duration_cast<std::chrono::seconds>(duration).count();
3999         if (std::abs(durationInSeconds) > time) {
4000             iter = list.erase(iter);
4001         } else {
4002             break;
4003         }
4004     }
4005 }
4006 
PublishEvent(int32_t mediaPlayState)4007 void AVSessionService::PublishEvent(int32_t mediaPlayState)
4008 {
4009     OHOS::AAFwk::Want want;
4010     want.SetAction(MEDIA_CONTROL_STATE);
4011     want.SetParam(MEDIA_PLAY_STATE, mediaPlayState);
4012     EventFwk::CommonEventData data;
4013     data.SetWant(want);
4014     EventFwk::CommonEventPublishInfo publishInfo;
4015     int ret = EventFwk::CommonEventManager::NewPublishCommonEvent(data, publishInfo);
4016     SLOGI("NewPublishCommonEvent:%{public}d return %{public}d", mediaPlayState, ret);
4017 }
4018 
GetDefaultImageStr()4019 std::string GetDefaultImageStr()
4020 {
4021     std::string imgStr = ""
4022     "mlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5r"
4023     "PSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KCTxkZXNjPgoJCQlDcmVhdGVkIHdpdGggUGl4c28uCgk8L2Rlc2M+Cgk8ZGV"
4024     "mcy8+Cgk8ZyBvcGFjaXR5PSIwLjMwMDAwMCI+CgkJPGNpcmNsZSBpZD0i6JKZ54mIIiByPSIxMi4wMDAwMDAiIHRyYW5zZm9ybT0ibW"
4025     "F0cml4KDAgMSAtMSAwIDEyIDEyKSIgZmlsbD0iI0ZGRkZGRiIgZmlsbC1vcGFjaXR5PSIxLjAwMDAwMCIvPgoJCTxjaXJjbGUgaWQ9I"
4026     "uiSmeeJiCIgcj0iMTEuNTAwMDAwIiB0cmFuc2Zvcm09Im1hdHJpeCgwIDEgLTEgMCAxMiAxMikiIHN0cm9rZT0iI0ZGRkZGRiIgc3Ry"
4027     "b2tlLW9wYWNpdHk9IjAiIHN0cm9rZS13aWR0aD0iMS4wMDAwMDAiLz4KCTwvZz4KCTxtYXNrIGlkPSJtYXNrXzE1M183OTU5IiBmaWx"
4028     "sPSJ3aGl0ZSI+CgkJPHBhdGggaWQ9IuW9oueKtue7k+WQiCIgZD0iTTE3LjY0MzYgNi42NTM5OUMxNy42NTM1IDYuNzE2OCAxNy42Nj"
4029     "AxIDYuNzgwMDkgMTcuNjYzNCA2Ljg0MzUxTDE3LjY2NTkgNi45Mzg4NEwxNy42NjY2IDE0LjE2NjZDMTcuNjY2NiAxNC4xNzk3IDE3L"
4030     "jY2NjIgMTQuMTkyNiAxNy42NjU1IDE0LjIwNTVDMTcuNjYxNiAxNC44NjgzIDE3LjY1NDYgMTUuMTgzNyAxNy41MTE0IDE1LjcxNDlD"
4031     "MTcuMzY1OCAxNi4yNTQzIDE3LjA4MDkgMTYuNzYyMSAxNi41MTMyIDE3LjA4OTRDMTUuNDggMTcuNjg0OCAxNC4yMjggMTcuNDUwOSA"
4032     "xMy43MTY3IDE2LjU2NjlDMTMuMjA1NCAxNS42ODI5IDEzLjYyODUgMTQuNDgzNSAxNC42NjE2IDEzLjg4ODFDMTUuMDg2MSAxMy42ND"
4033     "M0IDE1LjYyNTcgMTMuNDI3MSAxNS45OTg5IDEzLjA4NTVDMTYuMjIzIDEyLjg4MDQgMTYuMzMyMiAxMi41ODU1IDE2LjMzMjIgMTEuO"
4034     "TE4OEMxNi4zMzIyIDExLjkwMDQgMTYuMzMyNSAxMS44ODI0IDE2LjMzMyAxMS44NjUxTDE2LjMzMjcgOC41MDk4OUw5LjY2NjU2IDku"
4035     "Njg2MjhMOS42NjY1NiAxNS4xMzEyQzkuNjY3MyAxNS4yNzA4IDkuNjY3MjQgMTUuNDExMyA5LjY2NjU2IDE1LjU1MDNMOS42NjY1NiA"
4036     "xNS42NjY3QzkuNjY2NTYgMTUuNjc4MyA5LjY2NjI2IDE1LjY4OTggOS42NjU2NSAxNS43MDE0QzkuNjYxNSAxNi4zMDk2IDkuNjQ5Mz"
4037     "UgMTYuNjIwNCA5LjUxMjA4IDE3LjEyOTVDOS4zNjY1OCAxNy42Njg4IDkuMDgxNiAxOC4xNzY3IDguNTEzOTIgMTguNTAzOUM3LjQ4M"
4038     "DcxIDE5LjA5OTQgNi4yMjg3IDE4Ljg2NTQgNS43MTc0MSAxNy45ODE0QzUuMjA2MTIgMTcuMDk3NCA1LjYyOTIxIDE1Ljg5OCA2LjY2"
4039     "MjM1IDE1LjMwMjZDNy4wODY3OSAxNS4wNTggNy42MjY0IDE0Ljg0MTcgNy45OTk2MyAxNC41QzguMjIzNjkgMTQuMjk0OSA4LjMzMjk"
4040     "1IDE0IDguMzMyOTUgMTMuMzMzM0M4LjMzMjk1IDEzLjMyMjcgOC4zMzMwNyAxMy4zMTIyIDguMzMzMjUgMTMuMzAxOUw4LjMzMzI1ID"
4041     "cuODMwNzVDOC4zMzMyNSA2Ljk2NzUzIDguOTM0MTQgNi4yMjcwNSA5Ljc2NjYgNi4wNDE1Nkw5Ljg4MTUzIDYuMDE5NzFMMTUuNTQ3N"
4042     "SA1LjEyNzk5QzE2LjU0NzcgNC45NzA1MiAxNy40ODYyIDUuNjUzNzUgMTcuNjQzNiA2LjY1Mzk5WiIgY2xpcC1ydWxlPSJldmVub2Rk"
4043     "IiBmaWxsPSIiIGZpbGwtb3BhY2l0eT0iMS4wMDAwMDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPgoJPC9tYXNrPgoJPHBhdGggaWQ9IuW"
4044     "9oueKtue7k+WQiCIgZD0iTTE3LjY0MzYgNi42NTM5OUMxNy42NTM1IDYuNzE2OCAxNy42NjAxIDYuNzgwMDkgMTcuNjYzNCA2Ljg0Mz"
4045     "UxTDE3LjY2NTkgNi45Mzg4NEwxNy42NjY2IDE0LjE2NjZDMTcuNjY2NiAxNC4xNzk3IDE3LjY2NjIgMTQuMTkyNiAxNy42NjU1IDE0L"
4046     "jIwNTVDMTcuNjYxNiAxNC44NjgzIDE3LjY1NDYgMTUuMTgzNyAxNy41MTE0IDE1LjcxNDlDMTcuMzY1OCAxNi4yNTQzIDE3LjA4MDkg"
4047     "MTYuNzYyMSAxNi41MTMyIDE3LjA4OTRDMTUuNDggMTcuNjg0OCAxNC4yMjggMTcuNDUwOSAxMy43MTY3IDE2LjU2NjlDMTMuMjA1NCA"
4048     "xNS42ODI5IDEzLjYyODUgMTQuNDgzNSAxNC42NjE2IDEzLjg4ODFDMTUuMDg2MSAxMy42NDM0IDE1LjYyNTcgMTMuNDI3MSAxNS45OT"
4049     "g5IDEzLjA4NTVDMTYuMjIzIDEyLjg4MDQgMTYuMzMyMiAxMi41ODU1IDE2LjMzMjIgMTEuOTE4OEMxNi4zMzIyIDExLjkwMDQgMTYuM"
4050     "zMyNSAxMS44ODI0IDE2LjMzMyAxMS44NjUxTDE2LjMzMjcgOC41MDk4OUw5LjY2NjU2IDkuNjg2MjhMOS42NjY1NiAxNS4xMzEyQzku"
4051     "NjY3MyAxNS4yNzA4IDkuNjY3MjQgMTUuNDExMyA5LjY2NjU2IDE1LjU1MDNMOS42NjY1NiAxNS42NjY3QzkuNjY2NTYgMTUuNjc4MyA"
4052     "5LjY2NjI2IDE1LjY4OTggOS42NjU2NSAxNS43MDE0QzkuNjYxNSAxNi4zMDk2IDkuNjQ5MzUgMTYuNjIwNCA5LjUxMjA4IDE3LjEyOT"
4053     "VDOS4zNjY1OCAxNy42Njg4IDkuMDgxNiAxOC4xNzY3IDguNTEzOTIgMTguNTAzOUM3LjQ4MDcxIDE5LjA5OTQgNi4yMjg3IDE4Ljg2N"
4054     "TQgNS43MTc0MSAxNy45ODE0QzUuMjA2MTIgMTcuMDk3NCA1LjYyOTIxIDE1Ljg5OCA2LjY2MjM1IDE1LjMwMjZDNy4wODY3OSAxNS4w"
4055     "NTggNy42MjY0IDE0Ljg0MTcgNy45OTk2MyAxNC41QzguMjIzNjkgMTQuMjk0OSA4LjMzMjk1IDE0IDguMzMyOTUgMTMuMzMzM0M4LjM"
4056     "zMjk1IDEzLjMyMjcgOC4zMzMwNyAxMy4zMTIyIDguMzMzMjUgMTMuMzAxOUw4LjMzMzI1IDcuODMwNzVDOC4zMzMyNSA2Ljk2NzUzID"
4057     "guOTM0MTQgNi4yMjcwNSA5Ljc2NjYgNi4wNDE1Nkw5Ljg4MTUzIDYuMDE5NzFMMTUuNTQ3NSA1LjEyNzk5QzE2LjU0NzcgNC45NzA1M"
4058     "iAxNy40ODYyIDUuNjUzNzUgMTcuNjQzNiA2LjY1Mzk5WiIgY2xpcC1ydWxlPSJldmVub2RkIiBmaWxsPSIjMDAwMDAwIiBmaWxsLW9w"
4059     "YWNpdHk9IjAuNDAwMDAwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIG1hc2s9InVybCgjbWFza18xNTNfNzk1OSkiLz4KCTxwYXRoIGlkPSL"
4060     "lvaLnirbnu5PlkIgiIGQ9IiIgY2xpcC1ydWxlPSJldmVub2RkIiBmaWxsPSIjMDAwMDAwIiBmaWxsLW9wYWNpdHk9IjAuMDAwMDAwIi"
4061     "BmaWxsLXJ1bGU9ImV2ZW5vZGQiLz4KPC9zdmc+Cg==";
4062     return imgStr;
4063 }
4064 
ConvertDefaultImage()4065 std::shared_ptr<Media::PixelMap> ConvertDefaultImage()
4066 {
4067     if (g_defaultMediaImage) {
4068         return g_defaultMediaImage;
4069     }
4070 
4071     std::string image = GetDefaultImageStr();
4072     uint32_t errorCode = 0;
4073     Media::SourceOptions opts;
4074     auto imageSource = Media::ImageSource::CreateImageSource(reinterpret_cast<const uint8_t*>(image.c_str()),
4075         image.length(), opts, errorCode);
4076     if (imageSource != nullptr) {
4077         Media::DecodeOptions dOpts;
4078         dOpts.allocatorType = Media::AllocatorType::HEAP_ALLOC;
4079         g_defaultMediaImage = imageSource->CreatePixelMap(dOpts, errorCode);
4080         if (g_defaultMediaImage != nullptr) {
4081             SLOGI("ConvertDefaultImage CreatePixelMap success");
4082             return g_defaultMediaImage;
4083         }
4084     } else {
4085         SLOGE("ConvertDefaultImage createImageSource fail");
4086     }
4087     return nullptr;
4088 }
4089 
4090 
AddCapsule(std::string title,bool isCapsuleUpdate,std::shared_ptr<AVSessionPixelMap> innerPixelMap,std::shared_ptr<Notification::NotificationLocalLiveViewContent> content,Notification::NotificationRequest * request)4091 void AddCapsule(std::string title, bool isCapsuleUpdate, std::shared_ptr<AVSessionPixelMap> innerPixelMap,
4092     std::shared_ptr<Notification::NotificationLocalLiveViewContent> content,
4093     Notification::NotificationRequest* request)
4094 {
4095     const float scaleSize = 0.3;
4096     std::shared_ptr<Media::PixelMap> pixelMap = AVSessionPixelMapAdapter::ConvertFromInner(innerPixelMap);
4097     if (pixelMap == nullptr) {
4098         SLOGI("AddCapsule ConvertDefaultImage");
4099         pixelMap = ConvertDefaultImage();
4100     } else {
4101         pixelMap->scale(scaleSize, scaleSize, Media::AntiAliasingOption::HIGH);
4102     }
4103     auto capsule = Notification::NotificationCapsule();
4104     capsule.SetIcon(pixelMap);
4105     capsule.SetTitle(title);
4106     if (isCapsuleUpdate) {
4107         std::shared_ptr<AAFwk::WantParams> wantParam = std::make_shared<AAFwk::WantParams>();
4108         wantParam->SetParam("hw_capsule_icon_animation_type", OHOS::AAFwk::Integer::Box(1));
4109         SLOGI("MediaCapsule CapsuleUpdate");
4110         request->SetAdditionalData(wantParam);
4111     }
4112 
4113     if (!g_isCapsuleLive2) {
4114         capsule.SetBackgroundColor("#2E3033");
4115     }
4116 
4117     content->SetCapsule(capsule);
4118     content->addFlag(Notification::NotificationLocalLiveViewContent::LiveViewContentInner::CAPSULE);
4119     SLOGI("PublishNotification with MediaCapsule");
4120 }
4121 
NotifyFlowControl()4122 bool AVSessionService::NotifyFlowControl()
4123 {
4124     // flow control
4125     std::chrono::system_clock::time_point now = std::chrono::system_clock::now();
4126     RemoveExpired(flowControlPublishTimestampList_, now);
4127     if (flowControlPublishTimestampList_.size() >= MAX_NOTIFICATION_NUM) {
4128         SLOGE("PublishNotification Exeed MAX_NOTIFICATION_NUM");
4129         return true;
4130     }
4131     flowControlPublishTimestampList_.push_back(now);
4132     return false;
4133 }
4134 
CreateNftRemoveWant(int32_t uid)4135 std::shared_ptr<AbilityRuntime::WantAgent::WantAgent> AVSessionService::CreateNftRemoveWant(int32_t uid)
4136 {
4137     std::vector<std::shared_ptr<AAFwk::Want>> wants;
4138     std::shared_ptr<AAFwk::Want> want = std::make_shared<AAFwk::Want>();
4139     want->SetAction("EVENT_REMOVE_MEDIACONTROLLER_LIVEVIEW");
4140     wants.push_back(want);
4141     AbilityRuntime::WantAgent::WantAgentInfo wantAgentInfo(
4142         0,
4143         AbilityRuntime::WantAgent::WantAgentConstant::OperationType::SEND_COMMON_EVENT,
4144         AbilityRuntime::WantAgent::WantAgentConstant::Flags::UPDATE_PRESENT_FLAG,
4145         wants,
4146         nullptr
4147     );
4148     return AbilityRuntime::WantAgent::WantAgentHelper::GetWantAgent(wantAgentInfo, uid);
4149 }
4150 
GetLocalTitle()4151 std::string AVSessionService::GetLocalTitle()
4152 {
4153     AVMetaData meta = topSession_->GetMetaData();
4154     bool isTitleLyric = (topSession_->GetBundleName() == DEFAULT_BUNDLE_NAME) && !meta.GetDescription().empty();
4155     bool isAncoLyric = (topSession_->GetUid() == audioBrokerUid && meta.GetArtist().find("-") != std::string::npos);
4156     std::string songName;
4157     if (isTitleLyric) {
4158         std::string description = meta.GetDescription();
4159         size_t pos = description.find(";");
4160         if (pos != std::string::npos) {
4161             songName = description.substr(0, pos);
4162         }
4163         SLOGI("GetLocalTitle description:%{public}s, title:%{public}s", description.c_str(), songName.c_str());
4164     } else if (isAncoLyric) {
4165         std::string ancoTitle = meta.GetArtist();
4166         size_t posi = ancoTitle.find("-");
4167         if (posi != std::string::npos) {
4168             songName = ancoTitle.substr(0, posi);
4169         }
4170         SLOGI("GetLocalTitle isAncoLyric title:%{public}s", songName.c_str());
4171     }
4172     std::string localTitle = isTitleLyric || isAncoLyric ? songName : meta.GetTitle();
4173     SLOGI("GetLocalTitle localTitle:%{public}s", localTitle.c_str());
4174     return localTitle;
4175 }
4176 
4177 // LCOV_EXCL_START
NotifySystemUI(const AVSessionDescriptor * historyDescriptor,bool isActiveSession,bool addCapsule,bool isCapsuleUpdate)4178 void AVSessionService::NotifySystemUI(const AVSessionDescriptor* historyDescriptor, bool isActiveSession,
4179     bool addCapsule, bool isCapsuleUpdate)
4180 {
4181     CHECK_AND_RETURN_LOG(!is2in1_, "2in1 not support.");
4182     int32_t result = Notification::NotificationHelper::SubscribeLocalLiveViewNotification(NOTIFICATION_SUBSCRIBER);
4183     CHECK_AND_RETURN_LOG(result == ERR_OK, "create notification subscriber error %{public}d", result);
4184     SLOGI("NotifySystemUI isActiveNtf %{public}d addCapsule %{public}d isCapsuleUpdate %{public}d",
4185         isActiveSession, addCapsule, isCapsuleUpdate);
4186     hasMediaCapsule_ = addCapsule;
4187     Notification::NotificationRequest request;
4188     std::shared_ptr<Notification::NotificationLocalLiveViewContent> localLiveViewContent =
4189         std::make_shared<Notification::NotificationLocalLiveViewContent>();
4190     CHECK_AND_RETURN_LOG(localLiveViewContent != nullptr, "avsession item local live view content nullptr error");
4191     localLiveViewContent->SetType(SYSTEMUI_LIVEVIEW_TYPECODE_MDEDIACONTROLLER);
4192     localLiveViewContent->SetTitle(historyDescriptor && !isActiveSession ? "" : "AVSession NotifySystemUI");
4193     localLiveViewContent->SetText(historyDescriptor && !isActiveSession ? "" : "AVSession NotifySystemUI");
4194 
4195     std::shared_ptr<Notification::NotificationContent> content =
4196         std::make_shared<Notification::NotificationContent>(localLiveViewContent);
4197     CHECK_AND_RETURN_LOG(content != nullptr, "avsession item notification content nullptr error");
4198     int32_t userId = historyDescriptor ? historyDescriptor->userId_ : GetUsersManager().GetCurrentUserId();
4199     SLOGD("get historyDescriptor %{public}d with userId:%{public}d",
4200         static_cast<int>(historyDescriptor != nullptr), userId);
4201     if (addCapsule && topSession_) {
4202         std::shared_ptr<AVSessionPixelMap> iPixelMap = std::make_shared<AVSessionPixelMap>();
4203         topSession_->ReadMetaDataImg(iPixelMap);
4204         AVQueueItem item;
4205         topSession_->GetCurrentCastItem(item);
4206         std::string notifyText = item.GetDescription() && item.GetDescription()->GetPcmSrc() ?
4207             item.GetDescription()->GetTitle() : GetLocalTitle();
4208         AddCapsule(notifyText, isCapsuleUpdate, iPixelMap, localLiveViewContent, &(request));
4209         AVSessionEventHandler::GetInstance().AVSessionRemoveTask("CheckCardStateChangeStop");
4210         hasCardStateChangeStopTask_ = false;
4211     }
4212 
4213     auto uid = topSession_ ? (topSession_->GetUid() == audioBrokerUid ?
4214         BundleStatusAdapter::GetInstance().GetUidFromBundleName(topSession_->GetBundleName(), userId) :
4215         topSession_->GetUid()) : (historyDescriptor ? historyDescriptor->uid_ : -1);
4216     bool isBroker = topSession_ != nullptr && topSession_->GetUid() == audioBrokerUid;
4217     request.SetSlotType(Notification::NotificationConstant::SlotType::LIVE_VIEW);
4218     request.SetNotificationId(0);
4219     request.SetContent(content);
4220     request.SetCreatorUid(avSessionUid);
4221     request.SetUnremovable(true);
4222     request.SetInProgress(true);
4223     request.SetOwnerUid(uid);
4224     request.SetIsAgentNotification(true);
4225     if (isBroker) {
4226         request.SetOwnerUserId(defaultUserId);
4227     }
4228     std::shared_ptr<AbilityRuntime::WantAgent::WantAgent> wantAgent = CreateWantAgent(historyDescriptor);
4229     CHECK_AND_RETURN_LOG(wantAgent != nullptr, "wantAgent nullptr error");
4230     request.SetWantAgent(wantAgent);
4231     request.SetLabel(std::to_string(userId));
4232     if (topSession_) {
4233         if (topSession_->IsNotShowNotification()) {
4234             std::shared_ptr<AAFwk::WantParams> want = std::make_shared<AAFwk::WantParams>();
4235             want->SetParam("hw_live_view_hidden_when_keyguard", OHOS::AAFwk::Boolean::Box(true));
4236             SLOGI("PublishNotification with hw_live_view_hidden_when_keyguard uid: %{public}d", uid);
4237             request.SetAdditionalData(want);
4238         }
4239     }
4240     std::shared_ptr<AbilityRuntime::WantAgent::WantAgent> removeWantAgent = CreateNftRemoveWant(uid);
4241     request.SetRemovalWantAgent(removeWantAgent);
4242     {
4243         std::lock_guard lockGuard(notifyLock_);
4244         g_NotifyRequest = request;
4245     }
4246     AVSessionEventHandler::GetInstance().AVSessionRemoveTask("NotifyFlowControl");
4247     Notification::NotificationHelper::SetHashCodeRule(1);
4248     if (NotifyFlowControl()) {
4249         AVSessionEventHandler::GetInstance().AVSessionPostTask(
4250             [this, uid, isBroker]() {
4251                 bool isTopSessionNtf = false;
4252                 {
4253                     std::lock_guard lockGuard(sessionServiceLock_);
4254                     isTopSessionNtf = topSession_ != nullptr && (topSession_->GetUid() == uid ||
4255                         (isBroker && topSession_->GetUid() == audioBrokerUid));
4256                 }
4257                 std::lock_guard lockGuard(notifyLock_);
4258                 hasRemoveEvent_ = false;
4259                 if (isTopSessionNtf) {
4260                     auto ret = Notification::NotificationHelper::PublishNotification(g_NotifyRequest);
4261                     SLOGI("WaitPublish uid %{public}d, isTop %{public}d result %{public}d", uid, isTopSessionNtf, ret);
4262                 }
4263             }, "NotifyFlowControl", CLICK_TIMEOUT);
4264     } else {
4265         hasRemoveEvent_ = false;
4266         result = Notification::NotificationHelper::PublishNotification(request);
4267         SLOGI("PublishNotification uid %{public}d, user id %{public}d, result %{public}d", uid, userId, result);
4268     }
4269 }
4270 // LCOV_EXCL_STOP
4271 
NotifyRemoteDistributedSessionControllersChanged(const std::vector<sptr<IRemoteObject>> & sessionControllers)4272 void AVSessionService::NotifyRemoteDistributedSessionControllersChanged(
4273     const std::vector<sptr<IRemoteObject>>& sessionControllers)
4274 {
4275     SLOGI("NotifyRemoteDistributedSessionControllersChanged size: %{public}d", (int) sessionControllers.size());
4276     std::lock_guard lockGuard(sessionListenersLock_);
4277     std::map<pid_t, sptr<ISessionListener>> listenerMap = GetUsersManager().GetSessionListener();
4278     for (const auto& [pid, listener] : listenerMap) {
4279         AVSESSION_TRACE_SYNC_START("AVSessionService::OnSessionCreate");
4280         if (listener != nullptr) {
4281             listener->OnRemoteDistributedSessionChange(sessionControllers);
4282         }
4283     }
4284     std::map<pid_t, sptr<ISessionListener>> listenerMapForAll = GetUsersManager().GetSessionListenerForAllUsers();
4285     for (const auto& [pid, listener] : listenerMapForAll) {
4286         AVSESSION_TRACE_SYNC_START("AVSessionService::OnSessionCreate");
4287         if (listener != nullptr) {
4288             listener->OnRemoteDistributedSessionChange(sessionControllers);
4289         }
4290     }
4291 
4292     {
4293         std::lock_guard lockGuard(migrateListenersLock_);
4294         for (const auto& listener : innerSessionListeners_) {
4295             if (listener != nullptr) {
4296                 listener->OnRemoteDistributedSessionChange(sessionControllers);
4297             }
4298         }
4299     }
4300 }
4301 
InitRadarBMS()4302 void AVSessionService::InitRadarBMS()
4303 {
4304     AVSessionRadar::GetInstance().InitBMS();
4305 }
4306 
GetAllowedPlaybackCallbackFunc()4307 std::function<bool(int32_t, int32_t)> AVSessionService::GetAllowedPlaybackCallbackFunc()
4308 {
4309     return [](int32_t uid, int32_t pid) -> bool {
4310         auto mgr = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
4311         CHECK_AND_RETURN_RET_LOG(mgr != nullptr, true, "SystemAbilityManager is null");
4312         auto object = mgr->CheckSystemAbility(APP_MGR_SERVICE_ID);
4313         CHECK_AND_RETURN_RET_LOG(object != nullptr, true, "APP_MAGR_SERVICE is null");
4314         bool hasSession = GetContainer().PidHasSession(pid);
4315         bool isBack = AppManagerAdapter::GetInstance().IsAppBackground(uid, pid);
4316         bool isSystem = PermissionChecker::GetInstance().CheckSystemPermissionByUid(uid);
4317         auto ret = hasSession || isSystem || !isBack;
4318         SLOGI("avsession uid=%{public}d pid=%{public}d hasSession=%{public}d isBack=%{public}d isSystem=%{public}d",
4319             uid, pid, hasSession, isBack, isSystem);
4320         return ret;
4321     };
4322 }
4323 
4324 #ifdef ENABLE_AVSESSION_SYSEVENT_CONTROL
GetVersionName(const std::string & bundleName)4325 static std::string GetVersionName(const std::string& bundleName)
4326 {
4327     std::string versionName = "";
4328     auto samgr = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
4329     if (samgr == nullptr) {
4330         SLOGE("Get ability manager failed");
4331         return versionName;
4332     }
4333 
4334     sptr<IRemoteObject> object = samgr->GetSystemAbility(BUNDLE_MGR_SERVICE_SYS_ABILITY_ID);
4335     if (object == nullptr) {
4336         SLOGE("object is NULL.");
4337         return versionName;
4338     }
4339 
4340     sptr<OHOS::AppExecFwk::IBundleMgr> bms = iface_cast<OHOS::AppExecFwk::IBundleMgr>(object);
4341     if (bms == nullptr) {
4342         SLOGE("bundle manager service is NULL.");
4343         return versionName;
4344     }
4345 
4346     AppExecFwk::BundleInfo bundleInfo;
4347     if (!bms->GetBundleInfo(bundleName,
4348         static_cast<int32_t>(AppExecFwk::GetBundleInfoFlag::GET_BUNDLE_INFO_WITH_APPLICATION),
4349         bundleInfo, AppExecFwk::Constants::ALL_USERID)) {
4350             SLOGE("GetBundleInfo=%{public}s fail", bundleName.c_str());
4351             return versionName;
4352     }
4353     versionName = bundleInfo.versionName;
4354     if (versionName.empty()) {
4355         SLOGE("get versionName form application failed.");
4356         return versionName;
4357     }
4358     return versionName;
4359 }
4360 
ReportSessionState(const sptr<AVSessionItem> & session,SessionState state)4361 void AVSessionService::ReportSessionState(const sptr<AVSessionItem>& session, SessionState state)
4362 {
4363     if (session == nullptr) {
4364         SLOGE("ReportSessionState session is null");
4365         return;
4366     }
4367     AVSessionSysEvent::GetInstance().UpdateState(session->GetBundleName(),
4368         GetVersionName(session->GetBundleName()), state);
4369 }
4370 
ReportSessionControl(const std::string & bundleName,int32_t cmd)4371 void AVSessionService::ReportSessionControl(const std::string& bundleName, int32_t cmd)
4372 {
4373     if (cmd == AVControlCommand::SESSION_CMD_PLAY ||
4374         cmd == AVControlCommand::SESSION_CMD_PAUSE ||
4375         cmd == CONTROL_COLD_START) {
4376         AVSessionSysEvent::GetInstance().UpdateControl(bundleName, cmd,
4377             BundleStatusAdapter::GetInstance().GetBundleNameFromUid(GetCallingUid()));
4378     }
4379 }
4380 
4381 #endif // ENABLE_AVSESSION_SYSEVENT_CONTROL
4382 } // namespace OHOS::AVSession
4383