• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2022 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 "daudio_source_service.h"
17 
18 #include "if_system_ability_manager.h"
19 #include "ipc_skeleton.h"
20 #include "ipc_types.h"
21 #include "iservice_registry.h"
22 #include "string_ex.h"
23 #include "system_ability_definition.h"
24 
25 #include "daudio_constants.h"
26 #include "daudio_errorcode.h"
27 #include "daudio_hisysevent.h"
28 #include "daudio_log.h"
29 #include "daudio_radar.h"
30 #include "daudio_source_manager.h"
31 #include "daudio_util.h"
32 
33 #include "token_setproc.h"
34 
35 #undef DH_LOG_TAG
36 #define DH_LOG_TAG "DAudioSourceService"
37 
38 namespace OHOS {
39 namespace DistributedHardware {
40 REGISTER_SYSTEM_ABILITY_BY_ID(DAudioSourceService, DISTRIBUTED_HARDWARE_AUDIO_SOURCE_SA_ID, true);
OnStart()41 void DAudioSourceService::OnStart()
42 {
43     DHLOGI("Distributed audio service on start.");
44     if (!Init()) {
45         DHLOGE("Init service failed.");
46         return;
47     }
48     DHLOGI("Start distributed audio service success.");
49 }
50 
OnStop()51 void DAudioSourceService::OnStop()
52 {
53     DHLOGI("Distributed audio service on stop.");
54     isServiceStarted_ = false;
55 }
56 
Init()57 bool DAudioSourceService::Init()
58 {
59     if (!isServiceStarted_) {
60         DHLOGI("Publish distributed audio service.");
61         bool ret = Publish(this);
62         if (!ret) {
63             DHLOGE("Publish service failed.");
64             return false;
65         }
66         isServiceStarted_ = true;
67     }
68     return true;
69 }
70 
InitSource(const std::string & params,const sptr<IDAudioIpcCallback> & callback)71 int32_t DAudioSourceService::InitSource(const std::string &params, const sptr<IDAudioIpcCallback> &callback)
72 {
73     DHLOGI("Init source service.");
74     (void)params;
75     int32_t ret = DAudioSourceManager::GetInstance().Init(callback);
76     if (ret != DH_SUCCESS) {
77         DHLOGE("Distributed audio source manager init failed.");
78         return ret;
79     }
80     return DH_SUCCESS;
81 }
82 
ReleaseSource()83 int32_t DAudioSourceService::ReleaseSource()
84 {
85     DHLOGI("Release source service.");
86     DAudioHisysevent::GetInstance().SysEventWriteBehavior(DAUDIO_EXIT, "daudio source sa exit success.");
87     DAudioSourceManager::GetInstance().UnInit();
88     DHLOGD("Audio source service process exit.");
89     auto systemAbilityMgr = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
90     CHECK_NULL_RETURN(systemAbilityMgr, ERR_DH_AUDIO_NULLPTR);
91     int32_t ret = systemAbilityMgr->UnloadSystemAbility(DISTRIBUTED_HARDWARE_AUDIO_SOURCE_SA_ID);
92     if (ret != DH_SUCCESS) {
93         DHLOGE("Source systemabilitymgr unloadsystemability failed, ret: %{public}d", ret);
94         return ERR_DH_AUDIO_SA_LOAD_FAILED;
95     }
96     DHLOGD("Source systemabilitymgr unloadsystemability successfully!");
97     return DH_SUCCESS;
98 }
99 
RegisterDistributedHardware(const std::string & devId,const std::string & dhId,const EnableParam & param,const std::string & reqId)100 int32_t DAudioSourceService::RegisterDistributedHardware(const std::string &devId, const std::string &dhId,
101     const EnableParam &param, const std::string &reqId)
102 {
103     DHLOGI("Register distributed audio device, devId: %{public}s, dhId: %{public}s.", GetAnonyString(devId).c_str(),
104         dhId.c_str());
105     std::string version = param.sinkVersion;
106     std::string attrs = param.sinkAttrs;
107     auto callerTokenId = GetFirstCallerTokenID();
108     DAudioSourceManager::GetInstance().SetCallerTokenId(callerTokenId);
109     return DAudioSourceManager::GetInstance().EnableDAudio(devId, dhId, version, attrs, reqId);
110 }
111 
UnregisterDistributedHardware(const std::string & devId,const std::string & dhId,const std::string & reqId)112 int32_t DAudioSourceService::UnregisterDistributedHardware(const std::string &devId, const std::string &dhId,
113     const std::string &reqId)
114 {
115     DHLOGI("Unregister distributed audio device, devId: %{public}s, dhId: %{public}s.", GetAnonyString(devId).c_str(),
116         dhId.c_str());
117     DaudioRadar::GetInstance().ReportDaudioUnInit("UnregisterDistributedHardware", AudioUnInit::UNREGISTER,
118         BizState::BIZ_STATE_START, DH_SUCCESS);
119     return DAudioSourceManager::GetInstance().DisableDAudio(devId, dhId, reqId);
120 }
121 
ConfigDistributedHardware(const std::string & devId,const std::string & dhId,const std::string & key,const std::string & value)122 int32_t DAudioSourceService::ConfigDistributedHardware(const std::string &devId, const std::string &dhId,
123     const std::string &key, const std::string &value)
124 {
125     DHLOGI("Config distributed audio device, devId: %{public}s, dhId: %{public}s.", GetAnonyString(devId).c_str(),
126         dhId.c_str());
127     return DH_SUCCESS;
128 }
129 
DAudioNotify(const std::string & devId,const std::string & dhId,const int32_t eventType,const std::string & eventContent)130 void DAudioSourceService::DAudioNotify(const std::string &devId, const std::string &dhId, const int32_t eventType,
131     const std::string &eventContent)
132 {
133     DHLOGD("Notify distributed audio device, devId: %{public}s, dhId: %{public}s.", GetAnonyString(devId).c_str(),
134         dhId.c_str());
135     DAudioSourceManager::GetInstance().HandleDAudioNotify(devId, dhId, eventType, eventContent);
136 }
137 
Dump(int32_t fd,const std::vector<std::u16string> & args)138 int DAudioSourceService::Dump(int32_t fd, const std::vector<std::u16string>& args)
139 {
140     DHLOGD("Distributed audio source service dump.");
141     std::string result;
142     std::vector<std::string> argsStr;
143 
144     std::transform(args.cbegin(), args.cend(), std::back_inserter(argsStr),
145         [](const std::u16string& item) { return Str16ToStr8(item); });
146 
147     if (!DaudioHidumper::GetInstance().Dump(argsStr, result)) {
148         DHLOGE("Hidump error");
149         return ERR_DH_AUDIO_BAD_VALUE;
150     }
151 
152     int ret = dprintf(fd, "%s\n", result.c_str());
153     if (ret < 0) {
154         DHLOGE("Dprintf error");
155         return ERR_DH_AUDIO_BAD_VALUE;
156     }
157 
158     return DH_SUCCESS;
159 }
160 } // namespace DistributedHardware
161 } // namespace OHOS