1c29fa5a6Sopenharmony_ci/* 2c29fa5a6Sopenharmony_ci * Copyright (c) 2021-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 "get_device_node.h" 17c29fa5a6Sopenharmony_ci 18c29fa5a6Sopenharmony_ci#undef MMI_LOG_TAG 19c29fa5a6Sopenharmony_ci#define MMI_LOG_TAG "GetDeviceNode" 20c29fa5a6Sopenharmony_ci 21c29fa5a6Sopenharmony_cinamespace OHOS { 22c29fa5a6Sopenharmony_cinamespace MMI { 23c29fa5a6Sopenharmony_cinamespace { 24c29fa5a6Sopenharmony_ciconst std::string DEVICES_INFO_PATH = "/proc/bus/input/devices"; 25c29fa5a6Sopenharmony_ciconstexpr int32_t READ_CMD_BUFF_SIZE { 1024 }; 26c29fa5a6Sopenharmony_ci} // namespace 27c29fa5a6Sopenharmony_ci 28c29fa5a6Sopenharmony_ciGetDeviceNode::GetDeviceNode() 29c29fa5a6Sopenharmony_ci{ 30c29fa5a6Sopenharmony_ci InitDeviceInfo(); 31c29fa5a6Sopenharmony_ci} 32c29fa5a6Sopenharmony_ci 33c29fa5a6Sopenharmony_ciint32_t GetDeviceNode::GetDeviceNodeName(const std::string &targetName, uint16_t devIndex, std::string &deviceNode) 34c29fa5a6Sopenharmony_ci{ 35c29fa5a6Sopenharmony_ci std::vector<std::string> devices = ReadDeviceFile(); 36c29fa5a6Sopenharmony_ci if (devices.empty()) { 37c29fa5a6Sopenharmony_ci MMI_HILOGE("Devices is empty"); 38c29fa5a6Sopenharmony_ci return RET_ERR; 39c29fa5a6Sopenharmony_ci } 40c29fa5a6Sopenharmony_ci std::map<std::string, std::vector<std::string>> deviceList; 41c29fa5a6Sopenharmony_ci AnalyseDevices(devices, deviceList); 42c29fa5a6Sopenharmony_ci if (deviceList.empty()) { 43c29fa5a6Sopenharmony_ci MMI_HILOGE("Device list is empty"); 44c29fa5a6Sopenharmony_ci return RET_ERR; 45c29fa5a6Sopenharmony_ci } 46c29fa5a6Sopenharmony_ci std::string deviceName = deviceList_[targetName]; 47c29fa5a6Sopenharmony_ci auto iter = deviceList.find(deviceName); 48c29fa5a6Sopenharmony_ci if (iter == deviceList.end()) { 49c29fa5a6Sopenharmony_ci MMI_HILOGE("Failed to find deviceName:%{public}s", deviceName.c_str()); 50c29fa5a6Sopenharmony_ci return RET_ERR; 51c29fa5a6Sopenharmony_ci } 52c29fa5a6Sopenharmony_ci size_t targetSize = iter->second.size(); 53c29fa5a6Sopenharmony_ci if (devIndex > targetSize) { 54c29fa5a6Sopenharmony_ci MMI_HILOGE("Failed to devIndex:%{public}d > targetSize:%{public}zu", devIndex, targetSize); 55c29fa5a6Sopenharmony_ci return RET_ERR; 56c29fa5a6Sopenharmony_ci } 57c29fa5a6Sopenharmony_ci std::string nodeRootPath = "/dev/input/"; 58c29fa5a6Sopenharmony_ci deviceNode = nodeRootPath + iter->second[devIndex]; 59c29fa5a6Sopenharmony_ci MMI_HILOGI("%{public}s[%{public}d] --> %{public}s", targetName.c_str(), devIndex, 60c29fa5a6Sopenharmony_ci deviceNode.c_str()); 61c29fa5a6Sopenharmony_ci 62c29fa5a6Sopenharmony_ci return RET_OK; 63c29fa5a6Sopenharmony_ci} 64c29fa5a6Sopenharmony_ci 65c29fa5a6Sopenharmony_civoid GetDeviceNode::InitDeviceInfo() 66c29fa5a6Sopenharmony_ci{ 67c29fa5a6Sopenharmony_ci deviceList_["mouse"] = "Virtual Mouse"; 68c29fa5a6Sopenharmony_ci deviceList_["touch"] = "Virtual TouchScreen"; 69c29fa5a6Sopenharmony_ci deviceList_["finger"] = "Virtual Finger"; 70c29fa5a6Sopenharmony_ci deviceList_["pad"] = "Virtual Touchpad"; 71c29fa5a6Sopenharmony_ci deviceList_["pen"] = "Virtual Stylus"; 72c29fa5a6Sopenharmony_ci deviceList_["gamePad"] = "Virtual GamePad"; 73c29fa5a6Sopenharmony_ci deviceList_["joystick"] = "Virtual Joystick"; 74c29fa5a6Sopenharmony_ci deviceList_["remoteControl"] = "Virtual RemoteControl"; 75c29fa5a6Sopenharmony_ci deviceList_["knob model1"] = "Virtual KnobConsumerCtrl"; 76c29fa5a6Sopenharmony_ci deviceList_["knob model2"] = "Virtual Knob"; 77c29fa5a6Sopenharmony_ci deviceList_["knob model3"] = "Virtual KnobMouse"; 78c29fa5a6Sopenharmony_ci deviceList_["keyboard model1"] = "Virtual keyboard"; 79c29fa5a6Sopenharmony_ci deviceList_["keyboard model2"] = "Virtual KeyboardConsumerCtrl"; 80c29fa5a6Sopenharmony_ci deviceList_["keyboard model3"] = "Virtual KeyboardSysCtrl"; 81c29fa5a6Sopenharmony_ci deviceList_["trackball"] = "Virtual Trackball"; 82c29fa5a6Sopenharmony_ci deviceList_["trackpad model1"] = "Virtual TrackPadMouse"; 83c29fa5a6Sopenharmony_ci deviceList_["trackpad model2"] = "Virtual Trackpad"; 84c29fa5a6Sopenharmony_ci} 85c29fa5a6Sopenharmony_ci 86c29fa5a6Sopenharmony_cistd::vector<std::string> GetDeviceNode::ReadDeviceFile() 87c29fa5a6Sopenharmony_ci{ 88c29fa5a6Sopenharmony_ci char realPath[PATH_MAX] = {}; 89c29fa5a6Sopenharmony_ci if (realpath(DEVICES_INFO_PATH.c_str(), realPath) == nullptr) { 90c29fa5a6Sopenharmony_ci MMI_HILOGE("The path is error, path:%{public}s", DEVICES_INFO_PATH.c_str()); 91c29fa5a6Sopenharmony_ci return {}; 92c29fa5a6Sopenharmony_ci } 93c29fa5a6Sopenharmony_ci FILE* fp = fopen(DEVICES_INFO_PATH.c_str(), "r"); 94c29fa5a6Sopenharmony_ci if (fp == nullptr) { 95c29fa5a6Sopenharmony_ci MMI_HILOGW("Open file:%{public}s failed", DEVICES_INFO_PATH.c_str()); 96c29fa5a6Sopenharmony_ci return {}; 97c29fa5a6Sopenharmony_ci } 98c29fa5a6Sopenharmony_ci char buf[READ_CMD_BUFF_SIZE] = {}; 99c29fa5a6Sopenharmony_ci std::vector<std::string> deviceStrs; 100c29fa5a6Sopenharmony_ci while (fgets(buf, sizeof(buf), fp) != nullptr) { 101c29fa5a6Sopenharmony_ci deviceStrs.push_back(buf); 102c29fa5a6Sopenharmony_ci } 103c29fa5a6Sopenharmony_ci if (fclose(fp) != 0) { 104c29fa5a6Sopenharmony_ci MMI_HILOGW("Close file:%{public}s failed", DEVICES_INFO_PATH.c_str()); 105c29fa5a6Sopenharmony_ci } 106c29fa5a6Sopenharmony_ci return deviceStrs; 107c29fa5a6Sopenharmony_ci} 108c29fa5a6Sopenharmony_ci 109c29fa5a6Sopenharmony_civoid GetDeviceNode::AnalyseDevices(const std::vector<std::string> &deviceStrs, 110c29fa5a6Sopenharmony_ci std::map<std::string, std::vector<std::string>> &deviceList) const 111c29fa5a6Sopenharmony_ci{ 112c29fa5a6Sopenharmony_ci std::string name; 113c29fa5a6Sopenharmony_ci for (const auto &item : deviceStrs) { 114c29fa5a6Sopenharmony_ci if (item.empty()) { 115c29fa5a6Sopenharmony_ci MMI_HILOGE("Device info is empty"); 116c29fa5a6Sopenharmony_ci return; 117c29fa5a6Sopenharmony_ci } 118c29fa5a6Sopenharmony_ci std::string temp = item.substr(0, 1); 119c29fa5a6Sopenharmony_ci uint64_t endPos = 0; 120c29fa5a6Sopenharmony_ci uint64_t startPos = 0; 121c29fa5a6Sopenharmony_ci if (temp == "N") { 122c29fa5a6Sopenharmony_ci startPos = item.find("=") + strlen("N:"); 123c29fa5a6Sopenharmony_ci endPos = item.size() - 1; 124c29fa5a6Sopenharmony_ci name = item.substr(startPos, endPos - startPos - 1); 125c29fa5a6Sopenharmony_ci } 126c29fa5a6Sopenharmony_ci if (temp == "H") { 127c29fa5a6Sopenharmony_ci startPos = item.rfind("event"); 128c29fa5a6Sopenharmony_ci uint64_t eventLength = item.substr(startPos).find_first_of(" "); 129c29fa5a6Sopenharmony_ci std::string target = item.substr(startPos, eventLength); 130c29fa5a6Sopenharmony_ci if (!(name.empty())) { 131c29fa5a6Sopenharmony_ci deviceList[name].push_back(target); 132c29fa5a6Sopenharmony_ci name.clear(); 133c29fa5a6Sopenharmony_ci target.clear(); 134c29fa5a6Sopenharmony_ci } 135c29fa5a6Sopenharmony_ci } 136c29fa5a6Sopenharmony_ci } 137c29fa5a6Sopenharmony_ci} 138c29fa5a6Sopenharmony_ci} // namespace MMI 139c29fa5a6Sopenharmony_ci} // namespace OHOS