• 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 "extension_connection_observer.h"
17 #include "memmgr_log.h"
18 #include "reclaim_priority_manager.h"
19 
20 namespace OHOS {
21 namespace Memory {
22 namespace {
23 const std::string TAG = "ExtConnObs";
24 }
25 
OnExtensionConnected(const AbilityRuntime::ConnectionData & data)26 void ExtensionConnectionObserver::OnExtensionConnected(const AbilityRuntime::ConnectionData& data)
27 {
28     HILOGI("%{public}s(%{public}d,%{public}d) --> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d) "
29         "with type %{public}d", data.callerName.c_str(), data.callerPid, data.callerUid,
30         data.extensionBundleName.c_str(), data.extensionModuleName.c_str(), data.extensionName.c_str(),
31         data.extensionPid, data.extensionUid, static_cast<int32_t>(data.extensionType));
32 
33     ReclaimPriorityManager::GetInstance().UpdateReclaimPriorityWithCaller(data.callerPid,  data.callerUid,
34         data.callerName, data.extensionPid, data.extensionUid, data.extensionBundleName,
35         AppStateUpdateReason::BIND_EXTENSION);
36 }
37 
OnExtensionDisconnected(const AbilityRuntime::ConnectionData & data)38 void ExtensionConnectionObserver::OnExtensionDisconnected(const AbilityRuntime::ConnectionData& data)
39 {
40     HILOGI("%{public}s(%{public}d,%{public}d) -/-> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d) "
41         "with type %{public}d", data.callerName.c_str(), data.callerPid, data.callerUid,
42         data.extensionBundleName.c_str(), data.extensionModuleName.c_str(), data.extensionName.c_str(),
43         data.extensionPid, data.extensionUid, static_cast<int32_t>(data.extensionType));
44     ReclaimPriorityManager::GetInstance().UpdateReclaimPriorityWithCaller(data.callerPid,  data.callerUid,
45         data.callerName, data.extensionPid, data.extensionUid, data.extensionBundleName,
46         AppStateUpdateReason::UNBIND_EXTENSION);
47 }
48 
OnDlpAbilityOpened(const AbilityRuntime::DlpStateData & data)49 void ExtensionConnectionObserver::OnDlpAbilityOpened(const AbilityRuntime::DlpStateData& data)
50 {
51     HILOGI("%{public}s(%{public}d,%{public}d) --> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d)",
52         data.callerName.c_str(), data.callerPid, data.callerUid, data.targetBundleName.c_str(),
53         data.targetModuleName.c_str(), data.targetAbilityName.c_str(), data.targetPid, data.targetUid);
54 
55     ReclaimPriorityManager::GetInstance().UpdateReclaimPriorityWithCaller(data.callerPid, data.callerUid,
56         data.callerName, data.targetPid, data.targetUid, data.targetBundleName,
57         AppStateUpdateReason::BIND_EXTENSION);
58 }
59 
OnDlpAbilityClosed(const AbilityRuntime::DlpStateData & data)60 void ExtensionConnectionObserver::OnDlpAbilityClosed(const AbilityRuntime::DlpStateData& data)
61 {
62     HILOGI("%{public}s(%{public}d,%{public}d) -/-> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d)",
63         data.callerName.c_str(), data.callerPid, data.callerUid, data.targetBundleName.c_str(),
64         data.targetModuleName.c_str(), data.targetAbilityName.c_str(), data.targetPid, data.targetUid);
65     ReclaimPriorityManager::GetInstance().UpdateReclaimPriorityWithCaller(data.callerPid, data.callerUid,
66         data.callerName, data.targetPid, data.targetUid, data.targetBundleName,
67         AppStateUpdateReason::UNBIND_EXTENSION);
68 }
69 
OnServiceDied()70 void ExtensionConnectionObserver::OnServiceDied()
71 {
72     HILOGE("called");
73 }
74 } // namespace Memory
75 } // namespace OHOS
76