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