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 "manage_inject_device.h" 17c29fa5a6Sopenharmony_ci 18c29fa5a6Sopenharmony_ci#include <chrono> 19c29fa5a6Sopenharmony_ci#include <thread> 20c29fa5a6Sopenharmony_ci 21c29fa5a6Sopenharmony_ci#undef MMI_LOG_TAG 22c29fa5a6Sopenharmony_ci#define MMI_LOG_TAG "ManageInjectDevice" 23c29fa5a6Sopenharmony_ci 24c29fa5a6Sopenharmony_cinamespace OHOS { 25c29fa5a6Sopenharmony_cinamespace MMI { 26c29fa5a6Sopenharmony_cinamespace { 27c29fa5a6Sopenharmony_ciconstexpr int64_t INJECT_SLEEP_TIMES { 10 }; 28c29fa5a6Sopenharmony_ci} // namespace 29c29fa5a6Sopenharmony_ci 30c29fa5a6Sopenharmony_ciint32_t ManageInjectDevice::TransformJsonData(const DeviceItems &configData) 31c29fa5a6Sopenharmony_ci{ 32c29fa5a6Sopenharmony_ci CALL_DEBUG_ENTER; 33c29fa5a6Sopenharmony_ci if (configData.empty()) { 34c29fa5a6Sopenharmony_ci MMI_HILOGE("Input data from json file is empty"); 35c29fa5a6Sopenharmony_ci return RET_ERR; 36c29fa5a6Sopenharmony_ci } 37c29fa5a6Sopenharmony_ci for (const auto &item : configData) { 38c29fa5a6Sopenharmony_ci std::string deviceName = item.deviceName; 39c29fa5a6Sopenharmony_ci uint16_t devIndex = item.deviceIndex; 40c29fa5a6Sopenharmony_ci std::string deviceNode; 41c29fa5a6Sopenharmony_ci if (getDeviceNodeObject_.GetDeviceNodeName(deviceName, devIndex, deviceNode) == RET_ERR) { 42c29fa5a6Sopenharmony_ci MMI_HILOGE("Failed to get device:%{public}s node", deviceName.c_str()); 43c29fa5a6Sopenharmony_ci return RET_ERR; 44c29fa5a6Sopenharmony_ci } 45c29fa5a6Sopenharmony_ci InputEventArray inputEventArray = {}; 46c29fa5a6Sopenharmony_ci inputEventArray.deviceName = deviceName; 47c29fa5a6Sopenharmony_ci inputEventArray.target = deviceNode; 48c29fa5a6Sopenharmony_ci auto devicePtr = GetDeviceObject::CreateDeviceObject(deviceName); 49c29fa5a6Sopenharmony_ci CHKPR(devicePtr, RET_ERR); 50c29fa5a6Sopenharmony_ci int32_t ret = devicePtr->TransformJsonDataToInputData(item, inputEventArray); 51c29fa5a6Sopenharmony_ci if (devicePtr != nullptr) { 52c29fa5a6Sopenharmony_ci delete devicePtr; 53c29fa5a6Sopenharmony_ci devicePtr = nullptr; 54c29fa5a6Sopenharmony_ci } 55c29fa5a6Sopenharmony_ci if (ret == RET_ERR) { 56c29fa5a6Sopenharmony_ci MMI_HILOGE("Failed to read json file"); 57c29fa5a6Sopenharmony_ci return ret; 58c29fa5a6Sopenharmony_ci } 59c29fa5a6Sopenharmony_ci ret = SendEvent(inputEventArray); 60c29fa5a6Sopenharmony_ci if (ret == RET_ERR) { 61c29fa5a6Sopenharmony_ci MMI_HILOGE("Failed to send event"); 62c29fa5a6Sopenharmony_ci return ret; 63c29fa5a6Sopenharmony_ci } 64c29fa5a6Sopenharmony_ci } 65c29fa5a6Sopenharmony_ci return RET_OK; 66c29fa5a6Sopenharmony_ci} 67c29fa5a6Sopenharmony_ci 68c29fa5a6Sopenharmony_ciint32_t ManageInjectDevice::SendEvent(const InputEventArray &inputEventArray) 69c29fa5a6Sopenharmony_ci{ 70c29fa5a6Sopenharmony_ci return SendEventToDeviceNode(inputEventArray); 71c29fa5a6Sopenharmony_ci} 72c29fa5a6Sopenharmony_ci 73c29fa5a6Sopenharmony_ciint32_t ManageInjectDevice::SendEventToDeviceNode(const InputEventArray &inputEventArray) 74c29fa5a6Sopenharmony_ci{ 75c29fa5a6Sopenharmony_ci CALL_DEBUG_ENTER; 76c29fa5a6Sopenharmony_ci std::string deviceNode = inputEventArray.target; 77c29fa5a6Sopenharmony_ci if (deviceNode.empty()) { 78c29fa5a6Sopenharmony_ci MMI_HILOGE("Device node:%{public}s is not exit", deviceNode.c_str()); 79c29fa5a6Sopenharmony_ci return RET_ERR; 80c29fa5a6Sopenharmony_ci } 81c29fa5a6Sopenharmony_ci char realPath[PATH_MAX] = {}; 82c29fa5a6Sopenharmony_ci if (realpath(deviceNode.c_str(), realPath) == nullptr) { 83c29fa5a6Sopenharmony_ci MMI_HILOGE("Path is error, path:%{private}s", deviceNode.c_str()); 84c29fa5a6Sopenharmony_ci return RET_ERR; 85c29fa5a6Sopenharmony_ci } 86c29fa5a6Sopenharmony_ci int32_t fd = open(realPath, O_RDWR); 87c29fa5a6Sopenharmony_ci if (fd < 0) { 88c29fa5a6Sopenharmony_ci MMI_HILOGE("Open device node:%{public}s failed", deviceNode.c_str()); 89c29fa5a6Sopenharmony_ci return RET_ERR; 90c29fa5a6Sopenharmony_ci } 91c29fa5a6Sopenharmony_ci for (const auto &item : inputEventArray.events) { 92c29fa5a6Sopenharmony_ci if (write(fd, &item.event, sizeof(item.event)) < 0) { 93c29fa5a6Sopenharmony_ci MMI_HILOGE("Write event failed"); 94c29fa5a6Sopenharmony_ci close(fd); 95c29fa5a6Sopenharmony_ci fd = -1; 96c29fa5a6Sopenharmony_ci return RET_ERR; 97c29fa5a6Sopenharmony_ci }; 98c29fa5a6Sopenharmony_ci int64_t blockTime = (item.blockTime == 0) ? INJECT_SLEEP_TIMES : item.blockTime; 99c29fa5a6Sopenharmony_ci std::this_thread::sleep_for(std::chrono::milliseconds(blockTime)); 100c29fa5a6Sopenharmony_ci } 101c29fa5a6Sopenharmony_ci if (fd >= 0) { 102c29fa5a6Sopenharmony_ci close(fd); 103c29fa5a6Sopenharmony_ci fd = -1; 104c29fa5a6Sopenharmony_ci } 105c29fa5a6Sopenharmony_ci return RET_OK; 106c29fa5a6Sopenharmony_ci} 107c29fa5a6Sopenharmony_ci} // namespace MMI 108c29fa5a6Sopenharmony_ci} // namespace OHOS