1 /*
2 * Copyright (c) 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 "cj_accessibility_ffi.h"
16 #include <cstdint>
17 #include "cj_accessibility_utils.h"
18 #include "cj_accessibility_callback.h"
19 #include "cj_common_ffi.h"
20 #include "cj_lambda.h"
21 #include "accessibility_system_ability_client.h"
22 #include "accessibility_def.h"
23 #include "hilog_wrapper.h"
24 #include "securec.h"
25 #include "native/ffi_remote_data.h"
26
27 namespace OHOS {
28 namespace Accessibility {
29
ConvertStringToAccessibilityAbilityTypes(const std::string & type)30 static AccessibilityAbilityTypes ConvertStringToAccessibilityAbilityTypes(const std::string &type)
31 {
32 std::map<const std::string, AccessibilityAbilityTypes> accessibilityAbilityTypesTable = {
33 {"spoken", AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_SPOKEN},
34 {"haptic", AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_HAPTIC},
35 {"audible", AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_AUDIBLE},
36 {"visual", AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_VISUAL},
37 {"generic", AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_GENERIC},
38 {"all", AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_ALL},
39 };
40
41 if (accessibilityAbilityTypesTable.find(type) == accessibilityAbilityTypesTable.end()) {
42 HILOG_WARN("invalid key[%{public}s]", type.c_str());
43 return AccessibilityAbilityTypes::ACCESSIBILITY_ABILITY_TYPE_INVALID;
44 }
45
46 return accessibilityAbilityTypesTable.at(type);
47 }
48
ConvertStringToAbilityStateType(const std::string & type)49 static AbilityStateType ConvertStringToAbilityStateType(const std::string &type)
50 {
51 std::map<const std::string, AbilityStateType> abilityStateTypeTable = {
52 {"enable", AbilityStateType::ABILITY_STATE_ENABLE},
53 {"disable", AbilityStateType::ABILITY_STATE_DISABLE},
54 {"install", AbilityStateType::ABILITY_STATE_INSTALLED}};
55
56 if (abilityStateTypeTable.find(type) == abilityStateTypeTable.end()) {
57 HILOG_WARN("invalid key[%{public}s]", type.c_str());
58 return ABILITY_STATE_INVALID;
59 }
60
61 return abilityStateTypeTable.at(type);
62 }
63
64 extern "C" {
FfiAccIsOpenAccessibility(int32_t * errorCode)65 bool FfiAccIsOpenAccessibility(int32_t *errorCode)
66 {
67 bool status = false;
68 auto asaClient = AccessibilitySystemAbilityClient::GetInstance();
69 if (asaClient == nullptr) {
70 *errorCode = ERR_INPUT_INVALID;
71 HILOG_ERROR("AccessibilitySystemAbilityClient instance is nullptr.");
72 return status;
73 }
74 auto ret = asaClient->IsEnabled(status);
75 if (ret != RET_OK) {
76 *errorCode = ERR_INPUT_INVALID;
77 HILOG_ERROR("FfiAccIsOpenAccessibility called failed.");
78 }
79 return status;
80 }
81
FfiAccIsOpenTouchGuide(int32_t * errorCode)82 bool FfiAccIsOpenTouchGuide(int32_t *errorCode)
83 {
84 auto asaClient = AccessibilitySystemAbilityClient::GetInstance();
85 if (asaClient == nullptr) {
86 *errorCode = ERR_INPUT_INVALID;
87 HILOG_ERROR("AccessibilitySystemAbilityClient instance is nullptr.");
88 return false;
89 }
90 bool status = false;
91 auto ret = asaClient->IsTouchExplorationEnabled(status);
92 if (ret != RET_OK) {
93 *errorCode = ERR_INPUT_INVALID;
94 HILOG_ERROR("FfiAccIsOpenTouchGuide called failed.");
95 }
96 return status;
97 }
98
FfiAccIsScreenReaderOpen(int32_t * errorCode)99 bool FfiAccIsScreenReaderOpen(int32_t *errorCode)
100 {
101 auto asaClient = AccessibilitySystemAbilityClient::GetInstance();
102 bool status = false;
103 auto ret = asaClient->IsScreenReaderEnabled(status);
104 if (ret != RET_OK) {
105 *errorCode = ERR_INPUT_INVALID;
106 HILOG_ERROR("FfiAccIsOpenTouchGuide called failed.");
107 }
108 return status;
109 }
110
FfiAccGetAccessibilityExtensionList(char * cAbilityType,char * cStateType,int32_t * errorCode)111 CArrAccessibilityAbilityInfo FfiAccGetAccessibilityExtensionList(char *cAbilityType, char *cStateType,
112 int32_t *errorCode)
113 {
114 RetError errCode = RET_OK;
115 AbilityStateType stateTypes = ABILITY_STATE_INVALID;
116 uint32_t abilityTypes = 0;
117 CArrAccessibilityAbilityInfo arrAccAbiliyInfo = {
118 .size = 0
119 };
120
121 // parse inputs
122 std::string abilityTypeStr(cAbilityType);
123 std::string stateTypeStr(cStateType);
124 HILOG_DEBUG("abilityTypeStr = %{private}s", abilityTypeStr.c_str());
125 if (Utils::CheckAbilityType(abilityTypeStr)) {
126 abilityTypes = ConvertStringToAccessibilityAbilityTypes(abilityTypeStr);
127 } else {
128 *errorCode = ERR_INPUT_INVALID;
129 return arrAccAbiliyInfo;
130 }
131 HILOG_DEBUG("stateTypes = %{private}s", stateTypeStr.c_str());
132 if (Utils::CheckStateType(stateTypeStr)) {
133 stateTypes = ConvertStringToAbilityStateType(stateTypeStr);
134 } else {
135 errCode = RET_ERR_INVALID_PARAM;
136 }
137 std::vector<AccessibilityAbilityInfo> abilityList{};
138 if (errCode == RET_OK) {
139 auto asaClient = AccessibilitySystemAbilityClient::GetInstance();
140 if (asaClient) {
141 errCode = asaClient->GetAbilityList(abilityTypes, stateTypes, abilityList);
142 }
143 }
144 arrAccAbiliyInfo = Utils::ConvertArrAccAbilityInfo2CArr(abilityList, errCode);
145 if (errCode != RET_OK) {
146 *errorCode = ERR_INPUT_INVALID;
147 HILOG_ERROR("GetAbilityList failed or abilityList.size is 0.");
148 }
149 return arrAccAbiliyInfo;
150 }
151
FfiAccEventInfoInit(char * ctype,char * cBundleName,char * cTrigger,int32_t * errorCode)152 CEventInfo FfiAccEventInfoInit(char *ctype, char *cBundleName, char *cTrigger, int32_t *errorCode)
153 {
154 RetError errCode = RET_OK;
155 CEventInfo cEventInfo;
156 std::string eType(ctype);
157 std::string bundleName(cBundleName);
158 std::string action(cTrigger);
159 AccessibilityEventInfo eventInfo(Utils::GetValueFromStr(Utils::rEventTypeMap, eType, errCode, TYPE_VIEW_INVALID));
160 eventInfo.SetBundleName(bundleName);
161 ActionType act = Utils::GetValueFromStr(Utils::rActionMap, action, errCode, ACCESSIBILITY_ACTION_INVALID);
162 eventInfo.SetTriggerAction(act);
163 cEventInfo = Utils::ConvertEventInfo2C(eventInfo, errCode);
164 if (errCode != RET_OK) {
165 *errorCode = ERR_INPUT_INVALID;
166 HILOG_ERROR("ConvertEventInfo2C failed.");
167 }
168 return cEventInfo;
169 }
170
FfiAccSendAccessibilityEvent(CEventInfo event,int32_t * errorCode)171 void FfiAccSendAccessibilityEvent(CEventInfo event, int32_t *errorCode)
172 {
173 RetError errCode = RET_OK;
174 AccessibilityEventInfo eventInfo = Utils::ConvertEventInfo(event, errCode);
175 auto asaClient = AccessibilitySystemAbilityClient::GetInstance();
176 if (asaClient != nullptr) {
177 errCode = asaClient->SendEvent(eventInfo);
178 }
179 if (asaClient == nullptr || errCode != RET_OK) {
180 *errorCode = ERR_INPUT_INVALID;
181 HILOG_ERROR("FfiAccSendAccessibilityEvent failed.");
182 } else {
183 HILOG_INFO("FfiAccSendAccessibilityEvent success.");
184 }
185 }
186
FfiAccOn(char * cbType,void (* callback)(),int32_t * errorCode)187 void FfiAccOn(char *cbType, void (*callback)(), int32_t *errorCode)
188 {
189 std::string cbTypeStr(cbType);
190 auto cbFunc = CJLambda::Create(reinterpret_cast<void (*)(bool)>(callback));
191 if (cbFunc == nullptr) {
192 HILOG_ERROR("callback registered failed.");
193 *errorCode = ERR_INPUT_INVALID;
194 return;
195 }
196 if (cbTypeStr == "accessibilityStateChange") {
197 cjAccessibilityStateListeners_->SubscribeObserver(cbFunc);
198 } else if (cbTypeStr == "touchGuideStateChange") {
199 cjTouchGuideStateListeners_->SubscribeObserver(cbFunc);
200 } else {
201 HILOG_ERROR("callback type should only be 'accessibilityStateChange' or 'touchGuideStateChange'");
202 *errorCode = ERR_INPUT_INVALID;
203 return;
204 }
205 HILOG_INFO("FfiAccOn success.");
206 }
207 }
208 } // namespace Accessibility
209 } // namespace OHOS
210