• 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 "background_task_mgr_service.h"
17 #include "bgtask_config.h"
18 #include "bundle_manager_helper.h"
19 #include <functional>
20 #include "ability_manager_client.h"
21 #include "accesstoken_kit.h"
22 #include "bgtaskmgr_inner_errors.h"
23 #include "bundle_constants.h"
24 #include "common_event_manager.h"
25 #include "common_event_support.h"
26 #include "file_ex.h"
27 #include "ipc_skeleton.h"
28 #include "string_ex.h"
29 
30 #include "bgtaskmgr_log_wrapper.h"
31 #include <parameters.h>
32 
33 namespace OHOS {
34 namespace BackgroundTaskMgr {
35 namespace {
36 static constexpr int32_t NO_DUMP_PARAM_NUMS = 0;
37 static constexpr char BGMODE_PERMISSION[] = "ohos.permission.KEEP_BACKGROUND_RUNNING";
38 const int32_t ENG_MODE = OHOS::system::GetIntParameter("const.debuggable", 0);
39 const std::string BGTASK_SERVICE_NAME = "BgtaskMgrService";
40 const bool REGISTER_RESULT = SystemAbility::MakeAndRegisterAbility(
41     DelayedSingleton<BackgroundTaskMgrService>::GetInstance().get());
42 }
43 
BackgroundTaskMgrService()44 BackgroundTaskMgrService::BackgroundTaskMgrService()
45     : SystemAbility(BACKGROUND_TASK_MANAGER_SERVICE_ID, true) {}
46 
~BackgroundTaskMgrService()47 BackgroundTaskMgrService::~BackgroundTaskMgrService() {}
48 
OnStart()49 void BackgroundTaskMgrService::OnStart()
50 {
51     BGTASK_LOGI("BackgroundTaskMgrService service onStart.");
52     if (state_ == ServiceRunningState::STATE_RUNNING) {
53         BGTASK_LOGW("Service has already started.");
54         return;
55     }
56     Init();
57     AddSystemAbilityListener(APP_MGR_SERVICE_ID);
58     AddSystemAbilityListener(BUNDLE_MGR_SERVICE_SYS_ABILITY_ID);
59     AddSystemAbilityListener(SA_ID_VOIP_CALL_MANAGER);
60     AddSystemAbilityListener(SA_ID_HEALTH_SPORT);
61     AddSystemAbilityListener(SUSPEND_MANAGER_SYSTEM_ABILITY_ID);
62 }
63 
SetReady(uint32_t flag)64 void BackgroundTaskMgrService::SetReady(uint32_t flag)
65 {
66     BGTASK_LOGI("BackgroundTaskMgrService service SetReady.");
67     {
68         std::lock_guard<std::mutex> lock(readyMutex_);
69         if (dependsReady_ == ServiceReadyState::ALL_READY) {
70             return;
71         }
72         dependsReady_ |= flag;
73         if (dependsReady_ != ServiceReadyState::ALL_READY) {
74             return;
75         }
76     }
77     DelayedSingleton<BgtaskConfig>::GetInstance()->Init();
78     BGTASK_LOGI("BackgroundTaskMgrService service Publish.");
79     if (!Publish(DelayedSingleton<BackgroundTaskMgrService>::GetInstance().get())) {
80         BGTASK_LOGE("Service start failed!");
81         return;
82     }
83     state_ = ServiceRunningState::STATE_RUNNING;
84     BGTASK_LOGI("background task manager service start succeed!");
85 }
86 
OnAddSystemAbility(int32_t systemAbilityId,const std::string & deviceId)87 void BackgroundTaskMgrService::OnAddSystemAbility(int32_t systemAbilityId, const std::string& deviceId)
88 {
89     DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->OnAddSystemAbility(systemAbilityId, deviceId);
90 }
91 
OnRemoveSystemAbility(int32_t systemAbilityId,const std::string & deviceId)92 void BackgroundTaskMgrService::OnRemoveSystemAbility(int32_t systemAbilityId, const std::string& deviceId)
93 {
94     DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->OnRemoveSystemAbility(systemAbilityId, deviceId);
95     BgContinuousTaskMgr::GetInstance()->OnRemoveSystemAbility(systemAbilityId, deviceId);
96     DelayedSingleton<BgTransientTaskMgr>::GetInstance()->OnRemoveSystemAbility(systemAbilityId, deviceId);
97 }
98 
Init()99 void BackgroundTaskMgrService::Init()
100 {
101     runner_ = AppExecFwk::EventRunner::Create(BGTASK_SERVICE_NAME);
102     DelayedSingleton<BgTransientTaskMgr>::GetInstance()->Init(runner_);
103     DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->Init(runner_);
104     BgContinuousTaskMgr::GetInstance()->Init(runner_);
105 }
106 
OnStop()107 void BackgroundTaskMgrService::OnStop()
108 {
109     BgContinuousTaskMgr::GetInstance()->Clear();
110     DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->Clear();
111     state_ = ServiceRunningState::STATE_NOT_START;
112     BGTASK_LOGI("background task manager stop");
113 }
114 
CheckCallingToken()115 bool BackgroundTaskMgrService::CheckCallingToken()
116 {
117     Security::AccessToken::AccessTokenID tokenId = IPCSkeleton::GetCallingTokenID();
118     auto tokenFlag = Security::AccessToken::AccessTokenKit::GetTokenTypeFlag(tokenId);
119     if (tokenFlag == Security::AccessToken::ATokenTypeEnum::TOKEN_NATIVE ||
120         tokenFlag == Security::AccessToken::ATokenTypeEnum::TOKEN_SHELL) {
121         return true;
122     }
123     return false;
124 }
125 
CheckHapCalling(bool & isHap)126 bool BackgroundTaskMgrService::CheckHapCalling(bool &isHap)
127 {
128     Security::AccessToken::AccessTokenID tokenId = IPCSkeleton::GetCallingTokenID();
129     auto tokenFlag = Security::AccessToken::AccessTokenKit::GetTokenTypeFlag(tokenId);
130     if (tokenFlag == Security::AccessToken::ATokenTypeEnum::TOKEN_HAP) {
131         isHap = true;
132         return BundleManagerHelper::GetInstance()->CheckPermission(BGMODE_PERMISSION);
133     }
134     return false;
135 }
136 
RequestSuspendDelay(const std::string & reason,const sptr<IExpiredCallback> & callback,DelaySuspendInfo & delayInfo)137 ErrCode BackgroundTaskMgrService::RequestSuspendDelay(const std::string& reason,
138     const sptr<IExpiredCallback>& callback, DelaySuspendInfo &delayInfo)
139 {
140     std::u16string reasonu16 = Str8ToStr16(reason);
141     std::shared_ptr<DelaySuspendInfo> delayInfoPtr = std::make_shared<DelaySuspendInfo>(delayInfo);
142     ErrCode result = DelayedSingleton<BgTransientTaskMgr>::GetInstance()->RequestSuspendDelay(
143         reasonu16, callback, delayInfoPtr);
144     if (result == ERR_OK) {
145         delayInfo = *delayInfoPtr;
146     }
147     return result;
148 }
149 
CancelSuspendDelay(int32_t requestId)150 ErrCode BackgroundTaskMgrService::CancelSuspendDelay(int32_t requestId)
151 {
152     return DelayedSingleton<BgTransientTaskMgr>::GetInstance()->CancelSuspendDelay(requestId);
153 }
154 
GetRemainingDelayTime(int32_t requestId,int32_t & delayTime)155 ErrCode BackgroundTaskMgrService::GetRemainingDelayTime(int32_t requestId, int32_t &delayTime)
156 {
157     return DelayedSingleton<BgTransientTaskMgr>::GetInstance()->GetRemainingDelayTime(requestId, delayTime);
158 }
159 
ForceCancelSuspendDelay(int32_t requestId)160 void BackgroundTaskMgrService::ForceCancelSuspendDelay(int32_t requestId)
161 {
162     DelayedSingleton<BgTransientTaskMgr>::GetInstance()->ForceCancelSuspendDelay(requestId);
163 }
164 
StartBackgroundRunning(const ContinuousTaskParam & taskParam,int32_t & notificationId,int32_t & continuousTaskId)165 ErrCode BackgroundTaskMgrService::StartBackgroundRunning(const ContinuousTaskParam &taskParam,
166     int32_t& notificationId, int32_t& continuousTaskId)
167 {
168     auto paramPtr = sptr<ContinuousTaskParam>(new ContinuousTaskParam(taskParam));
169     ErrCode result = BgContinuousTaskMgr::GetInstance()->StartBackgroundRunning(paramPtr);
170     if (result == ERR_OK) {
171         notificationId = paramPtr->notificationId_;
172         continuousTaskId = paramPtr->continuousTaskId_;
173     }
174     return result;
175 }
176 
UpdateBackgroundRunning(const ContinuousTaskParam & taskParam,int32_t & notificationId,int32_t & continuousTaskId)177 ErrCode BackgroundTaskMgrService::UpdateBackgroundRunning(const ContinuousTaskParam &taskParam,
178     int32_t& notificationId, int32_t& continuousTaskId)
179 {
180     auto paramPtr = sptr<ContinuousTaskParam>(new ContinuousTaskParam(taskParam));
181     ErrCode result = BgContinuousTaskMgr::GetInstance()->UpdateBackgroundRunning(paramPtr);
182     if (result == ERR_OK) {
183         notificationId = paramPtr->notificationId_;
184         continuousTaskId = paramPtr->continuousTaskId_;
185     }
186     return result;
187 }
188 
RequestBackgroundRunningForInner(const ContinuousTaskParamForInner & taskParam)189 ErrCode BackgroundTaskMgrService::RequestBackgroundRunningForInner(const ContinuousTaskParamForInner &taskParam)
190 {
191     auto paramPtr = sptr<ContinuousTaskParamForInner>(new ContinuousTaskParamForInner(taskParam));
192     return BgContinuousTaskMgr::GetInstance()->RequestBackgroundRunningForInner(paramPtr);
193 }
194 
StopBackgroundRunning(const std::string & abilityName,const sptr<IRemoteObject> & abilityToken,int32_t abilityId)195 ErrCode BackgroundTaskMgrService::StopBackgroundRunning(const std::string &abilityName,
196     const sptr<IRemoteObject> &abilityToken, int32_t abilityId)
197 {
198     return BgContinuousTaskMgr::GetInstance()->StopBackgroundRunning(abilityName, abilityId);
199 }
200 
GetTransientTaskApps(std::vector<TransientTaskAppInfo> & list)201 ErrCode BackgroundTaskMgrService::GetTransientTaskApps(std::vector<TransientTaskAppInfo> &list)
202 {
203     if (!CheckCallingToken()) {
204         BGTASK_LOGW("GetTransientTaskApps not allowed");
205         return ERR_BGTASK_PERMISSION_DENIED;
206     }
207     std::vector<std::shared_ptr<TransientTaskAppInfo>> resultList;
208     ErrCode result = DelayedSingleton<BgTransientTaskMgr>::GetInstance()->GetTransientTaskApps(resultList);
209     if (result == ERR_OK) {
210         for (const auto& ptr : resultList) {
211             if (ptr != nullptr) {
212                 list.push_back(*ptr);
213             }
214         }
215     }
216 
217     return result;
218 }
219 
PauseTransientTaskTimeForInner(int32_t uid)220 ErrCode BackgroundTaskMgrService::PauseTransientTaskTimeForInner(int32_t uid)
221 {
222     return DelayedSingleton<BgTransientTaskMgr>::GetInstance()->PauseTransientTaskTimeForInner(uid);
223 }
224 
StartTransientTaskTimeForInner(int32_t uid)225 ErrCode BackgroundTaskMgrService::StartTransientTaskTimeForInner(int32_t uid)
226 {
227     return DelayedSingleton<BgTransientTaskMgr>::GetInstance()->StartTransientTaskTimeForInner(uid);
228 }
229 
GetContinuousTaskApps(std::vector<ContinuousTaskCallbackInfo> & list)230 ErrCode BackgroundTaskMgrService::GetContinuousTaskApps(std::vector<ContinuousTaskCallbackInfo> &list)
231 {
232     bool isHap = false;
233     pid_t callingPid = IPCSkeleton::GetCallingPid();
234     pid_t callingUid = IPCSkeleton::GetCallingUid();
235     if (!CheckCallingToken() && !CheckHapCalling(isHap)) {
236         BGTASK_LOGW("uid %{public}d pid %{public}d GetContinuousTaskApps not allowed", callingUid, callingPid);
237         return ERR_BGTASK_PERMISSION_DENIED;
238     }
239     std::vector<std::shared_ptr<ContinuousTaskCallbackInfo>> resultList;
240     ErrCode result = BgContinuousTaskMgr::GetInstance()->GetContinuousTaskApps(resultList);
241     if (result == ERR_OK) {
242         for (const auto& ptr : resultList) {
243             if (ptr != nullptr) {
244                 list.push_back(*ptr);
245             }
246         }
247     }
248 
249     return result;
250 }
251 
SubscribeBackgroundTask(const sptr<IBackgroundTaskSubscriber> & subscriber)252 ErrCode BackgroundTaskMgrService::SubscribeBackgroundTask(const sptr<IBackgroundTaskSubscriber>& subscriber)
253 {
254     bool isHap = false;
255     if (!CheckCallingToken() && !CheckHapCalling(isHap)) {
256         BGTASK_LOGW("SubscribeBackgroundTask not allowed");
257         return ERR_BGTASK_PERMISSION_DENIED;
258     }
259     pid_t callingPid = IPCSkeleton::GetCallingPid();
260     pid_t callingUid = IPCSkeleton::GetCallingUid();
261     BGTASK_LOGI("uid %{public}d pid %{public}d isHap %{public}d subscribe", callingUid, callingPid, isHap);
262     auto subscriberInfo = std::make_shared<SubscriberInfo>(subscriber, callingUid, callingPid, isHap);
263     if (BgContinuousTaskMgr::GetInstance()->AddSubscriber(subscriberInfo) != ERR_OK) {
264         BGTASK_LOGE("continuous task subscribe background task failed");
265         return ERR_BGTASK_SYS_NOT_READY;
266     }
267     if (!isHap) {
268         if (DelayedSingleton<BgTransientTaskMgr>::GetInstance()->SubscribeBackgroundTask(subscriber) != ERR_OK
269             || DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->AddSubscriber(subscriber) != ERR_OK) {
270             BGTASK_LOGE("transient task or efficiency resource subscribe background task failed");
271             return ERR_BGTASK_SYS_NOT_READY;
272         }
273     }
274     BGTASK_LOGW("subscribe background task success");
275     return ERR_OK;
276 }
277 
UnsubscribeBackgroundTask(const sptr<IBackgroundTaskSubscriber> & subscriber)278 ErrCode BackgroundTaskMgrService::UnsubscribeBackgroundTask(const sptr<IBackgroundTaskSubscriber>& subscriber)
279 {
280     bool isHap = false;
281     if (!CheckCallingToken() && !CheckHapCalling(isHap)) {
282         BGTASK_LOGW("UnsubscribeBackgroundTask not allowed");
283         return ERR_BGTASK_PERMISSION_DENIED;
284     }
285     if (BgContinuousTaskMgr::GetInstance()->RemoveSubscriber(subscriber) != ERR_OK) {
286         BGTASK_LOGE("continuous task unsubscribe background task failed");
287         return ERR_BGTASK_SYS_NOT_READY;
288     }
289     if (!isHap) {
290         if (DelayedSingleton<BgTransientTaskMgr>::GetInstance()->UnsubscribeBackgroundTask(subscriber) != ERR_OK
291             || DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->RemoveSubscriber(subscriber) != ERR_OK) {
292             BGTASK_LOGE("transient task or efficiency resource unsubscribe background task failed");
293             return ERR_BGTASK_SYS_NOT_READY;
294         }
295     }
296     BGTASK_LOGW("unsubscribe background task success");
297     return ERR_OK;
298 }
299 
HandleRequestExpired(const int32_t requestId)300 void BackgroundTaskMgrService::HandleRequestExpired(const int32_t requestId)
301 {
302     DelayedSingleton<BgTransientTaskMgr>::GetInstance()->HandleRequestExpired(requestId);
303 }
304 
HandleExpiredCallbackDeath(const wptr<IRemoteObject> & remote)305 void BackgroundTaskMgrService::HandleExpiredCallbackDeath(const wptr<IRemoteObject>& remote)
306 {
307     DelayedSingleton<BgTransientTaskMgr>::GetInstance()->HandleExpiredCallbackDeath(remote);
308 }
309 
HandleSubscriberDeath(const wptr<IRemoteObject> & remote)310 void BackgroundTaskMgrService::HandleSubscriberDeath(const wptr<IRemoteObject>& remote)
311 {
312     DelayedSingleton<BgTransientTaskMgr>::GetInstance()->HandleSubscriberDeath(remote);
313 }
314 
ApplyEfficiencyResources(const EfficiencyResourceInfo & resourceInfo)315 ErrCode BackgroundTaskMgrService::ApplyEfficiencyResources(const EfficiencyResourceInfo &resourceInfo)
316 {
317     auto resourcePtr = sptr<EfficiencyResourceInfo>(new EfficiencyResourceInfo(resourceInfo));
318     return DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->ApplyEfficiencyResources(resourcePtr);
319 }
320 
ResetAllEfficiencyResources()321 ErrCode BackgroundTaskMgrService::ResetAllEfficiencyResources()
322 {
323     return DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->ResetAllEfficiencyResources();
324 }
325 
GetEfficiencyResourcesInfos(std::vector<ResourceCallbackInfo> & appList,std::vector<ResourceCallbackInfo> & procList)326 ErrCode BackgroundTaskMgrService::GetEfficiencyResourcesInfos(
327     std::vector<ResourceCallbackInfo> &appList,
328     std::vector<ResourceCallbackInfo> &procList)
329 {
330     if (!CheckCallingToken()) {
331         BGTASK_LOGW("GetEfficiencyResourcesInfos not allowed");
332         return ERR_BGTASK_PERMISSION_DENIED;
333     }
334     std::vector<std::shared_ptr<ResourceCallbackInfo>> resultAppList;
335     std::vector<std::shared_ptr<ResourceCallbackInfo>> resultProcList;
336     ErrCode result = DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->
337         GetEfficiencyResourcesInfos(resultAppList, resultProcList);
338     if (result == ERR_OK) {
339         for (const auto& ptr : resultAppList) {
340             if (ptr != nullptr) {
341                 appList.push_back(*ptr);
342             }
343         }
344         for (const auto& ptr : resultProcList) {
345             if (ptr != nullptr) {
346                 procList.push_back(*ptr);
347             }
348         }
349     }
350     return result;
351 }
352 
StopContinuousTask(int32_t uid,int32_t pid,uint32_t taskType,const std::string & key)353 ErrCode BackgroundTaskMgrService::StopContinuousTask(int32_t uid, int32_t pid, uint32_t taskType,
354     const std::string &key)
355 {
356     if (!CheckCallingToken()) {
357         BGTASK_LOGW("StopContinuousTask not allowed");
358         return ERR_BGTASK_PERMISSION_DENIED;
359     }
360     BgContinuousTaskMgr::GetInstance()->StopContinuousTask(uid, pid, taskType, key);
361     return ERR_OK;
362 }
363 
SetBgTaskConfig(const std::string & configData,int32_t sourceType)364 ErrCode BackgroundTaskMgrService::SetBgTaskConfig(const std::string &configData, int32_t sourceType)
365 {
366     if (!CheckCallingToken()) {
367         BGTASK_LOGW("SetBgTaskConfig not allowed");
368         return ERR_BGTASK_PERMISSION_DENIED;
369     }
370     return DelayedSingleton<BgTransientTaskMgr>::GetInstance()->SetBgTaskConfig(configData, sourceType);
371 }
372 
AllowDump()373 bool BackgroundTaskMgrService::AllowDump()
374 {
375     if (ENG_MODE == 0) {
376         BGTASK_LOGE("Not eng mode");
377         return false;
378     }
379     Security::AccessToken::AccessTokenID tokenId = IPCSkeleton::GetFirstTokenID();
380     int32_t ret = Security::AccessToken::AccessTokenKit::VerifyAccessToken(tokenId, "ohos.permission.DUMP");
381     if (ret != Security::AccessToken::PermissionState::PERMISSION_GRANTED) {
382         BGTASK_LOGE("CheckPermission failed");
383         return false;
384     }
385     return true;
386 }
387 
Dump(int32_t fd,const std::vector<std::u16string> & args)388 int32_t BackgroundTaskMgrService::Dump(int32_t fd, const std::vector<std::u16string> &args)
389 {
390     if (!AllowDump()) {
391         return ERR_BGTASK_PERMISSION_DENIED;
392     }
393     std::vector<std::string> argsInStr;
394     std::transform(args.begin(), args.end(), std::back_inserter(argsInStr),
395         [](const std::u16string &arg) {
396         return Str16ToStr8(arg);
397     });
398     std::string result;
399 
400     int32_t ret = ERR_OK;
401 
402     if (argsInStr.size() == NO_DUMP_PARAM_NUMS) {
403         DumpUsage(result);
404     } else {
405         std::vector<std::string> infos;
406         if (argsInStr[0] == "-h") {
407             DumpUsage(result);
408         } else if (argsInStr[0] == "-T") {
409             ret = DelayedSingleton<BgTransientTaskMgr>::GetInstance()->ShellDump(argsInStr, infos);
410         } else if (argsInStr[0] == "-C") {
411             ret = BgContinuousTaskMgr::GetInstance()->ShellDump(argsInStr, infos);
412         } else if (argsInStr[0] == "-E") {
413             ret = DelayedSingleton<BgEfficiencyResourcesMgr>::GetInstance()->ShellDump(argsInStr, infos);
414         } else {
415             infos.emplace_back("Error params.\n");
416             ret = ERR_BGTASK_INVALID_PARAM;
417         }
418         for (auto info : infos) {
419             result.append(info);
420         }
421     }
422 
423     if (!SaveStringToFd(fd, result)) {
424         BGTASK_LOGE("BackgroundTaskMgrService dump save string to fd failed!");
425         ret = ERR_BGTASK_METHOD_CALLED_FAILED;
426     }
427     return ret;
428 }
429 
DumpUsage(std::string & result)430 void BackgroundTaskMgrService::DumpUsage(std::string &result)
431 {
432     std::string dumpHelpMsg =
433     "usage: bgtask dump [<options>]\n"
434     "options list:\n"
435     "    -h                                   help menu\n"
436     "    -T                                   transient task commands:\n"
437     "        BATTARY_LOW                          battary low mode\n"
438     "        BATTARY_OKAY                         battary okay mode\n"
439     "        DUMP_CANCEL                          cancel dump mode\n"
440     "        All                                  list all request\n"
441     "    -C                                   continuous task commands:\n"
442     "        --all                                list all running continuous task infos\n"
443     "        --cancel_all                         cancel all running continuous task\n"
444     "        --cancel {continuous task key}       cancel one task by specifying task key\n"
445     "    -E                                   efficiency resources commands;\n"
446     "        --all                                list all efficiency resource aplications\n"
447     "        --reset_all                          reset all efficiency resource aplications\n"
448     "        --resetapp {uid} {resources}          reset one application of uid by specifying \n"
449     "        --resetproc {pid} {resources}         reset one application of pid by specifying \n";
450 
451     result.append(dumpHelpMsg);
452 }  // namespace
453 }  // namespace BackgroundTaskMgr
454 }  // namespace OHOS
455