1c29fa5a6Sopenharmony_ci/*
2c29fa5a6Sopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
3c29fa5a6Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4c29fa5a6Sopenharmony_ci * you may not use this file except in compliance with the License.
5c29fa5a6Sopenharmony_ci * You may obtain a copy of the License at
6c29fa5a6Sopenharmony_ci *
7c29fa5a6Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8c29fa5a6Sopenharmony_ci *
9c29fa5a6Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10c29fa5a6Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11c29fa5a6Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12c29fa5a6Sopenharmony_ci * See the License for the specific language governing permissions and
13c29fa5a6Sopenharmony_ci * limitations under the License.
14c29fa5a6Sopenharmony_ci */
15c29fa5a6Sopenharmony_ci
16c29fa5a6Sopenharmony_ci#include "cooperate_hisysevent.h"
17c29fa5a6Sopenharmony_ci
18c29fa5a6Sopenharmony_ci#include "fi_log.h"
19c29fa5a6Sopenharmony_ci
20c29fa5a6Sopenharmony_ci#undef LOG_TAG
21c29fa5a6Sopenharmony_ci#define LOG_TAG "CooperateHiSysEvent"
22c29fa5a6Sopenharmony_ci
23c29fa5a6Sopenharmony_cinamespace OHOS {
24c29fa5a6Sopenharmony_cinamespace Msdp {
25c29fa5a6Sopenharmony_cinamespace DeviceStatus {
26c29fa5a6Sopenharmony_ci
27c29fa5a6Sopenharmony_cistd::map<CooperateState, std::string> CooperateDFX::CooperateState_ = {
28c29fa5a6Sopenharmony_ci    { CooperateState::COOPERATE_STATE_FREE, "STATE_FREE" },
29c29fa5a6Sopenharmony_ci    { CooperateState::COOPERATE_STATE_IN, "STATE_IN" },
30c29fa5a6Sopenharmony_ci    { CooperateState::COOPERATE_STATE_OUT, "STATE_OUT" },
31c29fa5a6Sopenharmony_ci};
32c29fa5a6Sopenharmony_ci
33c29fa5a6Sopenharmony_cistd::map<CooperateType, std::pair<std::string, std::string>> CooperateDFX::serialStr_ = {
34c29fa5a6Sopenharmony_ci    { CooperateType::ENABLE_SUCC, { "ENABLE_SUCCESS", "Enable cooperate successfully" } },
35c29fa5a6Sopenharmony_ci    { CooperateType::ENABLE_FAIL, { "ENABLE_FAILED", "Enable cooperate failed" } },
36c29fa5a6Sopenharmony_ci    { CooperateType::DISABLE_SUCC, { "DISABLE_SUCCESS", "Disenable cooperate successfully" } },
37c29fa5a6Sopenharmony_ci    { CooperateType::DISABLE_FAIL, { "DISABLE_FAILED", "Disenable cooperate failed" } },
38c29fa5a6Sopenharmony_ci    { CooperateType::LOCAL_ACTIVATE_SUCC, { "LOCAL_ACTIVATE_SUCCESS", "Local start cooperate successfully" } },
39c29fa5a6Sopenharmony_ci    { CooperateType::LOCAL_ACTIVATE_FAIL, { "LOCAL_ACTIVATEE_FAILED", "Local start cooperate failed" } },
40c29fa5a6Sopenharmony_ci    { CooperateType::REMOTE_ACTIVATE_SUCC, { "REMOTE_ACTIVATE_SUCCESS", "Remote start cooperate successfully" } },
41c29fa5a6Sopenharmony_ci    { CooperateType::REMOTE_ACTIVATE_FAIL, { "REMOTE_ACTIVATE_FAILED", "Remote start cooperate failed" } },
42c29fa5a6Sopenharmony_ci    { CooperateType::LOCAL_DEACTIVATE_SUCC, { "LOCAL_DEACTIVATE_SUCCESS", "Local stop cooperate successfully" } },
43c29fa5a6Sopenharmony_ci    { CooperateType::LOCAL_DEACTIVATE_FAIL, { "LOCAL_DEACTIVATE_FAILED", "Local stop cooperate failed" } },
44c29fa5a6Sopenharmony_ci    { CooperateType::REMOTE_DEACTIVATE_SUCC, { "REMOTE_DEACTIVATE_SUCCESS", "Remote stop cooperate successfully" } },
45c29fa5a6Sopenharmony_ci    { CooperateType::REMOTE_DEACTIVATE_FAIL, { "REMOTE_DEACTIVATE_FAILED", "Remote stop cooperate failed" } },
46c29fa5a6Sopenharmony_ci    { CooperateType::OPENSESSION_SUCC, { "OPENSESSION_SUCCESS", "Open session successfully" } },
47c29fa5a6Sopenharmony_ci    { CooperateType::OPENSESSION_FAIL, { "OPENSESSION_FAILED", "Open session failed" } },
48c29fa5a6Sopenharmony_ci    { CooperateType::UPDATESTATE_SUCC, { "UPDATESTATE_SUCCESS", "Update cooperatestate successfully" } },
49c29fa5a6Sopenharmony_ci    { CooperateType::START_SUCC, { "START_SUCCESS", "Start client successfully" } },
50c29fa5a6Sopenharmony_ci    { CooperateType::START_FAIL, { "START_FAILED", "Start client failed" } },
51c29fa5a6Sopenharmony_ci    { CooperateType::STOP_SUCC, { "STOP_SUCCESS", "Stop client successfully" } },
52c29fa5a6Sopenharmony_ci    { CooperateType::STOP_FAIL, { "STOP_FAILED", "Stop client failed" } },
53c29fa5a6Sopenharmony_ci};
54c29fa5a6Sopenharmony_ci
55c29fa5a6Sopenharmony_ci
56c29fa5a6Sopenharmony_citemplate<typename... Types>
57c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteInputFunc(const CooperateType &cooperateType,
58c29fa5a6Sopenharmony_ci    OHOS::HiviewDFX::HiSysEvent::EventType eventType, Types... paras)
59c29fa5a6Sopenharmony_ci{
60c29fa5a6Sopenharmony_ci    if (serialStr_.find(cooperateType) == serialStr_.end()) {
61c29fa5a6Sopenharmony_ci        FI_HILOGE("serialStr_ can't find the cooperate hisysevent type");
62c29fa5a6Sopenharmony_ci        return RET_ERR;
63c29fa5a6Sopenharmony_ci    }
64c29fa5a6Sopenharmony_ci    auto &[label, dec] = serialStr_[cooperateType];
65c29fa5a6Sopenharmony_ci    int32_t ret = HiSysEventWrite(
66c29fa5a6Sopenharmony_ci        OHOS::HiviewDFX::HiSysEvent::Domain::MSDP,
67c29fa5a6Sopenharmony_ci        label,
68c29fa5a6Sopenharmony_ci        eventType,
69c29fa5a6Sopenharmony_ci        paras...,
70c29fa5a6Sopenharmony_ci        "MSG",
71c29fa5a6Sopenharmony_ci        dec);
72c29fa5a6Sopenharmony_ci    if (ret != RET_OK) {
73c29fa5a6Sopenharmony_ci        FI_HILOGE("HiviewDFX write failed, ret:%{public}d", ret);
74c29fa5a6Sopenharmony_ci    }
75c29fa5a6Sopenharmony_ci    return ret;
76c29fa5a6Sopenharmony_ci}
77c29fa5a6Sopenharmony_ci
78c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteEnable(OHOS::HiviewDFX::HiSysEvent::EventType type)
79c29fa5a6Sopenharmony_ci{
80c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
81c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::ENABLE_SUCC, type);
82c29fa5a6Sopenharmony_ci    }
83c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::ENABLE_FAIL, type);
84c29fa5a6Sopenharmony_ci}
85c29fa5a6Sopenharmony_ci
86c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteDisable(OHOS::HiviewDFX::HiSysEvent::EventType type)
87c29fa5a6Sopenharmony_ci{
88c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
89c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::DISABLE_SUCC, type);
90c29fa5a6Sopenharmony_ci    }
91c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::DISABLE_FAIL, type);
92c29fa5a6Sopenharmony_ci}
93c29fa5a6Sopenharmony_ci
94c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteLocalStart(OHOS::HiviewDFX::HiSysEvent::EventType type)
95c29fa5a6Sopenharmony_ci{
96c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
97c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::LOCAL_ACTIVATE_SUCC, type);
98c29fa5a6Sopenharmony_ci    }
99c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::LOCAL_ACTIVATE_FAIL, type);
100c29fa5a6Sopenharmony_ci}
101c29fa5a6Sopenharmony_ci
102c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteRemoteStart(OHOS::HiviewDFX::HiSysEvent::EventType type)
103c29fa5a6Sopenharmony_ci{
104c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
105c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::REMOTE_ACTIVATE_SUCC, type);
106c29fa5a6Sopenharmony_ci    }
107c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::REMOTE_ACTIVATE_FAIL, type);
108c29fa5a6Sopenharmony_ci}
109c29fa5a6Sopenharmony_ci
110c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteLocalStop(OHOS::HiviewDFX::HiSysEvent::EventType type)
111c29fa5a6Sopenharmony_ci{
112c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
113c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::LOCAL_DEACTIVATE_SUCC, type);
114c29fa5a6Sopenharmony_ci    }
115c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::LOCAL_DEACTIVATE_FAIL, type);
116c29fa5a6Sopenharmony_ci}
117c29fa5a6Sopenharmony_ci
118c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteRemoteStop(OHOS::HiviewDFX::HiSysEvent::EventType type)
119c29fa5a6Sopenharmony_ci{
120c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
121c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::REMOTE_DEACTIVATE_SUCC, type);
122c29fa5a6Sopenharmony_ci    }
123c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::REMOTE_DEACTIVATE_FAIL, type);
124c29fa5a6Sopenharmony_ci}
125c29fa5a6Sopenharmony_ci
126c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteOpenSession(OHOS::HiviewDFX::HiSysEvent::EventType type)
127c29fa5a6Sopenharmony_ci{
128c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
129c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::OPENSESSION_SUCC, type);
130c29fa5a6Sopenharmony_ci    }
131c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::OPENSESSION_FAIL, type);
132c29fa5a6Sopenharmony_ci}
133c29fa5a6Sopenharmony_ci
134c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteStart(OHOS::HiviewDFX::HiSysEvent::EventType type)
135c29fa5a6Sopenharmony_ci{
136c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
137c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::START_SUCC, type);
138c29fa5a6Sopenharmony_ci    }
139c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::START_FAIL, type);
140c29fa5a6Sopenharmony_ci}
141c29fa5a6Sopenharmony_ci
142c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteStop(OHOS::HiviewDFX::HiSysEvent::EventType type)
143c29fa5a6Sopenharmony_ci{
144c29fa5a6Sopenharmony_ci    if (type == OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR) {
145c29fa5a6Sopenharmony_ci        return WriteInputFunc(CooperateType::STOP_SUCC, type);
146c29fa5a6Sopenharmony_ci    }
147c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::STOP_FAIL, type);
148c29fa5a6Sopenharmony_ci}
149c29fa5a6Sopenharmony_ci
150c29fa5a6Sopenharmony_ciint32_t CooperateDFX::WriteCooperateState(CooperateState curState)
151c29fa5a6Sopenharmony_ci{
152c29fa5a6Sopenharmony_ci    if (curState == CooperateState::N_COOPERATE_STATES) {
153c29fa5a6Sopenharmony_ci        return RET_ERR;
154c29fa5a6Sopenharmony_ci    }
155c29fa5a6Sopenharmony_ci    if (CooperateState_.find(curState) == CooperateState_.end()) {
156c29fa5a6Sopenharmony_ci        FI_HILOGE("CooperateState_ can't find the current cooperate state");
157c29fa5a6Sopenharmony_ci        return RET_ERR;
158c29fa5a6Sopenharmony_ci    }
159c29fa5a6Sopenharmony_ci    auto type = OHOS::HiviewDFX::HiSysEvent::EventType::BEHAVIOR;
160c29fa5a6Sopenharmony_ci    std::string currentState = CooperateState_[curState];
161c29fa5a6Sopenharmony_ci    return WriteInputFunc(CooperateType::UPDATESTATE_SUCC, type, "CurrentState", currentState);
162c29fa5a6Sopenharmony_ci}
163c29fa5a6Sopenharmony_ci} // namespace DeviceStatus
164c29fa5a6Sopenharmony_ci} // namespace Msdp
165c29fa5a6Sopenharmony_ci} // namespace OHOS
166