1 /*
2  * Copyright (c) 2023 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "dlp_permission_load_callback.h"
17 #include "dlp_permission_client.h"
18 #include "dlp_permission_log.h"
19 #include "i_dlp_permission_service.h"
20 
21 namespace OHOS {
22 namespace Security {
23 namespace DlpPermission {
24 namespace {
25 static constexpr OHOS::HiviewDFX::HiLogLabel LABEL = {LOG_CORE, SECURITY_DOMAIN_DLP_PERMISSION, "DlpPermissionClient"};
26 }  // namespace
DlpPermissionLoadCallback()27 DlpPermissionLoadCallback::DlpPermissionLoadCallback() {}
28 
OnLoadSystemAbilitySuccess(int32_t systemAbilityId,const sptr<IRemoteObject> & remoteObject)29 void DlpPermissionLoadCallback::OnLoadSystemAbilitySuccess(
30     int32_t systemAbilityId, const sptr<IRemoteObject>& remoteObject)
31 {
32     if (systemAbilityId != SA_ID_DLP_PERMISSION_SERVICE) {
33         DLP_LOG_ERROR(LABEL, "start systemabilityId is not dlp_permission!");
34         return;
35     }
36 
37     if (remoteObject == nullptr) {
38         DLP_LOG_ERROR(LABEL, "remoteObject is null.");
39         DlpPermissionClient::GetInstance().FinishStartSAFail();
40         return;
41     }
42 
43     DLP_LOG_INFO(LABEL, "Start systemAbilityId: %{public}d success!", systemAbilityId);
44 
45     DlpPermissionClient::GetInstance().FinishStartSASuccess(remoteObject);
46 }
47 
OnLoadSystemAbilityFail(int32_t systemAbilityId)48 void DlpPermissionLoadCallback::OnLoadSystemAbilityFail(int32_t systemAbilityId)
49 {
50     if (systemAbilityId != SA_ID_DLP_PERMISSION_SERVICE) {
51         DLP_LOG_ERROR(LABEL, "start systemabilityId is not dlp_permission!");
52         return;
53     }
54 
55     DLP_LOG_ERROR(LABEL, "Start systemAbilityId: %{public}d failed.", systemAbilityId);
56 
57     DlpPermissionClient::GetInstance().FinishStartSAFail();
58 }
59 }  // namespace DlpPermission
60 }  // namespace Security
61 }  // namespace OHOS