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 ReclaimHandleRequest request;
34 request.callerPid = data.callerPid;
35 request.callerUid = data.callerUid;
36 request.callerBundleName = data.callerName;
37 request.pid = data.extensionPid;
38 request.uid = data.extensionUid;
39 request.bundleName = data.extensionBundleName;
40 request.reason = AppStateUpdateReason::BIND_EXTENSION;
41 ReclaimPriorityManager::GetInstance().UpdateReclaimPriority(request);
42 }
43
OnExtensionDisconnected(const AbilityRuntime::ConnectionData & data)44 void ExtensionConnectionObserver::OnExtensionDisconnected(const AbilityRuntime::ConnectionData& data)
45 {
46 HILOGI("%{public}s(%{public}d,%{public}d) -/-> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d) "
47 "with type %{public}d", data.callerName.c_str(), data.callerPid, data.callerUid,
48 data.extensionBundleName.c_str(), data.extensionModuleName.c_str(), data.extensionName.c_str(),
49 data.extensionPid, data.extensionUid, static_cast<int32_t>(data.extensionType));
50 ReclaimHandleRequest request;
51 request.callerPid = data.callerPid;
52 request.callerUid = data.callerUid;
53 request.callerBundleName = data.callerName;
54 request.pid = data.extensionPid;
55 request.uid = data.extensionUid;
56 request.bundleName = data.extensionBundleName;
57 request.reason = AppStateUpdateReason::UNBIND_EXTENSION;
58 ReclaimPriorityManager::GetInstance().UpdateReclaimPriority(request);
59 }
60
OnDlpAbilityOpened(const AbilityRuntime::DlpStateData & data)61 void ExtensionConnectionObserver::OnDlpAbilityOpened(const AbilityRuntime::DlpStateData& data)
62 {
63 HILOGI("%{public}s(%{public}d,%{public}d) --> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d)",
64 data.callerName.c_str(), data.callerPid, data.callerUid, data.targetBundleName.c_str(),
65 data.targetModuleName.c_str(), data.targetAbilityName.c_str(), data.targetPid, data.targetUid);
66
67 ReclaimHandleRequest request;
68 request.callerPid = data.callerPid;
69 request.callerUid = data.callerUid;
70 request.callerBundleName = data.callerName;
71 request.pid = data.targetPid;
72 request.uid = data.targetUid;
73 request.bundleName = data.targetBundleName;
74 request.reason = AppStateUpdateReason::BIND_EXTENSION;
75 ReclaimPriorityManager::GetInstance().UpdateReclaimPriority(request);
76 }
77
OnDlpAbilityClosed(const AbilityRuntime::DlpStateData & data)78 void ExtensionConnectionObserver::OnDlpAbilityClosed(const AbilityRuntime::DlpStateData& data)
79 {
80 HILOGI("%{public}s(%{public}d,%{public}d) -/-> [%{public}s|%{public}s|%{public}s](%{public}d,%{public}d)",
81 data.callerName.c_str(), data.callerPid, data.callerUid, data.targetBundleName.c_str(),
82 data.targetModuleName.c_str(), data.targetAbilityName.c_str(), data.targetPid, data.targetUid);
83
84 ReclaimHandleRequest request;
85 request.callerPid = data.callerPid;
86 request.callerUid = data.callerUid;
87 request.callerBundleName = data.callerName;
88 request.pid = data.targetPid;
89 request.uid = data.targetUid;
90 request.bundleName = data.targetBundleName;
91 request.reason = AppStateUpdateReason::UNBIND_EXTENSION;
92 ReclaimPriorityManager::GetInstance().UpdateReclaimPriority(request);
93 }
94
OnServiceDied()95 void ExtensionConnectionObserver::OnServiceDied()
96 {
97 HILOGE("called");
98 }
99 } // namespace Memory
100 } // namespace OHOS
101