1 /*
2 * Copyright (c) 2023-2024 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 #include "test_processor.h"
16
17 #include <cinttypes>
18
19 #include "app_event_processor_mgr.h"
20 #include "hilog/log.h"
21
22 #undef LOG_DOMAIN
23 #define LOG_DOMAIN 0xD002D07
24
25 #undef LOG_TAG
26 #define LOG_TAG "TestProcessor"
27
28 namespace OHOS {
29 namespace HiviewDFX {
30 namespace HiAppEvent {
31 namespace {
PrintReportConfig(int64_t processorSeq)32 void PrintReportConfig(int64_t processorSeq)
33 {
34 ReportConfig config;
35 AppEventProcessorMgr::GetProcessorConfig(processorSeq, config);
36 HILOG_INFO(LOG_CORE, ".name=%{public}s", config.name.c_str());
37 HILOG_INFO(LOG_CORE, ".debugMode=%{public}d", config.debugMode);
38 HILOG_INFO(LOG_CORE, ".routeInfo=%{public}s", config.routeInfo.c_str());
39 HILOG_INFO(LOG_CORE, ".appId=%{public}s", config.appId.c_str());
40 HILOG_INFO(LOG_CORE, ".triggerCond.row=%{public}d", config.triggerCond.row);
41 HILOG_INFO(LOG_CORE, ".triggerCond.size=%{public}d", config.triggerCond.size);
42 HILOG_INFO(LOG_CORE, ".triggerCond.timeout=%{public}d", config.triggerCond.timeout);
43 HILOG_INFO(LOG_CORE, ".triggerCond.onStartup=%{public}d", config.triggerCond.onStartup);
44 HILOG_INFO(LOG_CORE, ".triggerCond.onBackground=%{public}d", config.triggerCond.onBackground);
45 HILOG_INFO(LOG_CORE, ".userIdNames.size=%{public}zu", config.userIdNames.size());
46 HILOG_INFO(LOG_CORE, ".userPropertyNames.size=%{public}zu", config.userPropertyNames.size());
47 HILOG_INFO(LOG_CORE, ".eventConfigs.size=%{public}zu", config.eventConfigs.size());
48 HILOG_INFO(LOG_CORE, ".configId=%{public}d", config.configId);
49 HILOG_INFO(LOG_CORE, ".customConfigs.size=%{public}zu", config.customConfigs.size());
50 }
51
PrintEvent(const AppEventInfo & event)52 void PrintEvent(const AppEventInfo& event)
53 {
54 HILOG_INFO(LOG_CORE, "AppEventInfo.domain=%{public}s", event.domain.c_str());
55 HILOG_INFO(LOG_CORE, "AppEventInfo.name=%{public}s", event.name.c_str());
56 HILOG_INFO(LOG_CORE, "AppEventInfo.eventType=%{public}d", event.eventType);
57 HILOG_INFO(LOG_CORE, "AppEventInfo.timestamp=%{public}" PRId64, event.timestamp);
58 HILOG_INFO(LOG_CORE, "AppEventInfo.params=%{public}s", event.params.c_str());
59 }
60 }
61
OnReport(int64_t processorSeq,const std::vector<UserId> & userIds,const std::vector<UserProperty> & userProperties,const std::vector<AppEventInfo> & events)62 int TestProcessor::OnReport(
63 int64_t processorSeq,
64 const std::vector<UserId>& userIds,
65 const std::vector<UserProperty>& userProperties,
66 const std::vector<AppEventInfo>& events)
67 {
68 HILOG_INFO(LOG_CORE, "OnReport start");
69 PrintReportConfig(processorSeq);
70 for (const auto& event : events) {
71 PrintEvent(event);
72 }
73 HILOG_INFO(LOG_CORE, "OnReport end");
74 return 0;
75 }
76
ValidateUserId(const UserId & userId)77 int TestProcessor::ValidateUserId(const UserId& userId)
78 {
79 return 0;
80 }
81
ValidateUserProperty(const UserProperty & userProperty)82 int TestProcessor::ValidateUserProperty(const UserProperty& userProperty)
83 {
84 return 0;
85 }
86
ValidateEvent(const AppEventInfo & event)87 int TestProcessor::ValidateEvent(const AppEventInfo& event)
88 {
89 return 0;
90 }
91 } // namespace HiAppEvent
92 } // namespace HiviewDFX
93 } // namespace OHOS
94