1 /*
2 * Copyright (c) 2022-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
16 #include "napi_edm_common.h"
17
18 #include "edm_constants.h"
19 #include "edm_errors.h"
20 #include "edm_log.h"
21 #include "js_native_api.h"
22 #include "js_native_api_types.h"
23 #include "napi/native_api.h"
24 #include "napi/native_common.h"
25 #include "napi/native_node_api.h"
26 #include "napi_edm_error.h"
27 #include "securec.h"
28
29 namespace OHOS {
30 namespace EDM {
31 const int32_t MAX_STRING_LEN = 10256;
NativeCallbackComplete(napi_env env,napi_status status,AsyncCallbackInfo * asyncCallbackInfo,napi_value result)32 static void NativeCallbackComplete(napi_env env, napi_status status, AsyncCallbackInfo *asyncCallbackInfo,
33 napi_value result)
34 {
35 EDMLOGD("NativeCallbackComplete asyncCallbackInfo->ret is %{public}d", asyncCallbackInfo->ret);
36 if (asyncCallbackInfo->deferred != nullptr) {
37 EDMLOGD("NativeCallbackComplete asyncCallbackInfo->deferred != nullptr");
38 if (asyncCallbackInfo->ret == ERR_OK) {
39 napi_resolve_deferred(env, asyncCallbackInfo->deferred, result);
40 } else {
41 if (asyncCallbackInfo->innerCodeMsg.empty()) {
42 napi_reject_deferred(env, asyncCallbackInfo->deferred, CreateError(env, asyncCallbackInfo->ret));
43 } else {
44 napi_reject_deferred(env, asyncCallbackInfo->deferred,
45 CreateErrorWithInnerCode(env, asyncCallbackInfo->ret, asyncCallbackInfo->innerCodeMsg));
46 }
47 }
48 } else {
49 napi_value callbackValue[ARGS_SIZE_TWO] = {0};
50 if (asyncCallbackInfo->ret == ERR_OK) {
51 napi_get_null(env, &callbackValue[ARR_INDEX_ZERO]);
52 callbackValue[ARR_INDEX_ONE] = result;
53 } else {
54 if (asyncCallbackInfo->innerCodeMsg.empty()) {
55 callbackValue[ARR_INDEX_ZERO] = CreateError(env, asyncCallbackInfo->ret);
56 } else {
57 callbackValue[ARR_INDEX_ZERO] =
58 CreateErrorWithInnerCode(env, asyncCallbackInfo->ret, asyncCallbackInfo->innerCodeMsg);
59 }
60 napi_get_null(env, &callbackValue[ARR_INDEX_ONE]);
61 }
62 napi_value callback = nullptr;
63 napi_value ret = nullptr;
64 napi_get_reference_value(env, asyncCallbackInfo->callback, &callback);
65 napi_call_function(env, nullptr, callback, std::size(callbackValue), callbackValue, &ret);
66 napi_delete_reference(env, asyncCallbackInfo->callback);
67 }
68 napi_delete_async_work(env, asyncCallbackInfo->asyncWork);
69 }
70
MatchValueType(napi_env env,napi_value value,napi_valuetype targetType)71 bool MatchValueType(napi_env env, napi_value value, napi_valuetype targetType)
72 {
73 napi_valuetype valueType = napi_undefined;
74 napi_typeof(env, value, &valueType);
75 return valueType == targetType;
76 }
77
ParseElementName(napi_env env,AppExecFwk::ElementName & elementName,napi_value args)78 bool ParseElementName(napi_env env, AppExecFwk::ElementName &elementName, napi_value args)
79 {
80 napi_valuetype valueType;
81 NAPI_CALL_BASE(env, napi_typeof(env, args, &valueType), false);
82 if (valueType != napi_object) {
83 EDMLOGE("Parameter element valueType error");
84 return false;
85 }
86 std::string bundleName;
87 std::string abilityName;
88 if (!JsObjectToString(env, args, "bundleName", true, bundleName) ||
89 !JsObjectToString(env, args, "abilityName", true, abilityName)) {
90 EDMLOGE("Parameter element bundleName error");
91 return false;
92 }
93 EDMLOGD("ParseElementName bundleName %{public}s ", bundleName.c_str());
94 EDMLOGD("ParseElementName abilityname %{public}s", abilityName.c_str());
95
96 elementName.SetBundleName(bundleName);
97 elementName.SetAbilityName(abilityName);
98 return true;
99 }
100
ParseMapStringAndString(napi_env env,std::map<std::string,std::string> & parameters,napi_value args)101 bool ParseMapStringAndString(napi_env env, std::map<std::string, std::string> ¶meters, napi_value args)
102 {
103 napi_valuetype valueType;
104
105 NAPI_CALL_BASE(env, napi_typeof(env, args, &valueType), false);
106 if (valueType != napi_object) {
107 EDMLOGE("Parameter 'args' is not an object.");
108 return false;
109 }
110
111 napi_value propertyNames;
112 NAPI_CALL_BASE(env, napi_get_property_names(env, args, &propertyNames), false);
113
114 uint32_t propertyCount;
115 NAPI_CALL_BASE(env, napi_get_array_length(env, propertyNames, &propertyCount), false);
116
117 for (uint32_t i = 0; i < propertyCount; ++i) {
118 napi_value key;
119 NAPI_CALL_BASE(env, napi_get_element(env, propertyNames, i, &key), false);
120
121 char keyBuf[256] = {0};
122 size_t keyLen;
123 NAPI_CALL_BASE(env, napi_get_value_string_utf8(env, key, keyBuf, sizeof(keyBuf) - 1, &keyLen), false);
124
125 napi_value value;
126 NAPI_CALL_BASE(env, napi_get_property(env, args, key, &value), false);
127
128 char valueBuf[MAX_STRING_LEN] = {0};
129 size_t valueLen;
130 NAPI_CALL_BASE(env, napi_get_value_string_utf8(env, value, valueBuf, sizeof(valueBuf) - 1, &valueLen), false);
131
132 parameters[keyBuf] = valueBuf;
133 }
134
135 return true;
136 }
137
ParseLong(napi_env env,int64_t & param,napi_value args)138 bool ParseLong(napi_env env, int64_t ¶m, napi_value args)
139 {
140 napi_valuetype valueType = napi_undefined;
141 if (napi_typeof(env, args, &valueType) != napi_ok || valueType != napi_number ||
142 napi_get_value_int64(env, args, ¶m) != napi_ok) {
143 EDMLOGE("Wrong argument type. int64 expected.");
144 return false;
145 }
146 return true;
147 }
148
ParseInt(napi_env env,int32_t & param,napi_value args)149 bool ParseInt(napi_env env, int32_t ¶m, napi_value args)
150 {
151 napi_valuetype valueType = napi_undefined;
152 if (napi_typeof(env, args, &valueType) != napi_ok || valueType != napi_number ||
153 napi_get_value_int32(env, args, ¶m) != napi_ok) {
154 EDMLOGE("Wrong argument type. int32 expected.");
155 return false;
156 }
157 return true;
158 }
159
ParseCallback(napi_env env,napi_ref & param,napi_value args)160 bool ParseCallback(napi_env env, napi_ref ¶m, napi_value args)
161 {
162 napi_valuetype valueType = napi_undefined;
163 if (napi_typeof(env, args, &valueType) != napi_ok || valueType != napi_function ||
164 napi_create_reference(env, args, NAPI_RETURN_ONE, ¶m) != napi_ok) {
165 EDMLOGE("Wrong argument type. napi_function expected.");
166 return false;
167 }
168 return true;
169 }
170
ParseUint(napi_env env,uint32_t & param,napi_value args)171 bool ParseUint(napi_env env, uint32_t ¶m, napi_value args)
172 {
173 napi_valuetype valueType = napi_undefined;
174 if (napi_typeof(env, args, &valueType) != napi_ok || valueType != napi_number ||
175 napi_get_value_uint32(env, args, ¶m) != napi_ok) {
176 EDMLOGE("Wrong argument type. uint32 expected.");
177 return false;
178 }
179 return true;
180 }
181
ParseBool(napi_env env,bool & param,napi_value args)182 bool ParseBool(napi_env env, bool ¶m, napi_value args)
183 {
184 napi_valuetype valueType = napi_undefined;
185 if (napi_typeof(env, args, &valueType) != napi_ok || valueType != napi_boolean ||
186 napi_get_value_bool(env, args, ¶m) != napi_ok) {
187 EDMLOGE("Wrong argument type. bool expected.");
188 return false;
189 }
190 return true;
191 }
192
ParseString(napi_env env,std::string & param,napi_value args)193 bool ParseString(napi_env env, std::string ¶m, napi_value args)
194 {
195 napi_valuetype valuetype;
196 if (napi_typeof(env, args, &valuetype) != napi_ok || valuetype != napi_string ||
197 !GetStringFromNAPI(env, args, param)) {
198 EDMLOGE("can not get string value");
199 return false;
200 }
201 EDMLOGD("ParseString param = %{public}s.", param.c_str());
202 return true;
203 }
204
GetStringFromNAPI(napi_env env,napi_value value,std::string & resultStr)205 bool GetStringFromNAPI(napi_env env, napi_value value, std::string &resultStr)
206 {
207 std::string result;
208 size_t size = 0;
209
210 if (napi_get_value_string_utf8(env, value, nullptr, NAPI_RETURN_ZERO, &size) != napi_ok) {
211 EDMLOGE("can not get string size");
212 return false;
213 }
214 result.reserve(size + NAPI_RETURN_ONE);
215 result.resize(size);
216 if (napi_get_value_string_utf8(env, value, result.data(), (size + NAPI_RETURN_ONE), &size) != napi_ok) {
217 EDMLOGE("can not get string value");
218 return false;
219 }
220 resultStr = result;
221 return true;
222 }
223
ParseCharArray(napi_env env,napi_value args,size_t maxLength,std::vector<char> & ret)224 bool ParseCharArray(napi_env env, napi_value args, size_t maxLength, std::vector<char> &ret)
225 {
226 napi_valuetype valuetype;
227 if (napi_typeof(env, args, &valuetype) != napi_ok || valuetype != napi_string) {
228 EDMLOGE("can not get string value");
229 return false;
230 }
231 size_t size = 0;
232 if (napi_get_value_string_utf8(env, args, nullptr, NAPI_RETURN_ZERO, &size) != napi_ok) {
233 EDMLOGE("can not get string size");
234 return false;
235 }
236 if (size >= maxLength) {
237 EDMLOGE("string size too long");
238 return false;
239 }
240 std::vector<char> buf(size + NAPI_RETURN_ONE);
241 if (napi_get_value_string_utf8(env, args, buf.data(), (size + NAPI_RETURN_ONE), &size) != napi_ok) {
242 EDMLOGE("can not get string value");
243 return false;
244 }
245 ret = buf;
246 memset_s(buf.data(), buf.size(), '\0', buf.size());
247 return true;
248 }
249
ParseStringArray(napi_env env,std::vector<std::string> & stringArray,napi_value args)250 napi_value ParseStringArray(napi_env env, std::vector<std::string> &stringArray, napi_value args)
251 {
252 EDMLOGD("begin to parse string array");
253 bool isArray = false;
254 NAPI_CALL(env, napi_is_array(env, args, &isArray));
255 if (!isArray) {
256 EDMLOGE("napi object is not array.");
257 return nullptr;
258 }
259 uint32_t arrayLength = 0;
260 NAPI_CALL(env, napi_get_array_length(env, args, &arrayLength));
261 EDMLOGD("length=%{public}ud", arrayLength);
262 for (uint32_t j = 0; j < arrayLength; j++) {
263 napi_value value = nullptr;
264 NAPI_CALL(env, napi_get_element(env, args, j, &value));
265 napi_valuetype valueType = napi_undefined;
266 NAPI_CALL(env, napi_typeof(env, value, &valueType));
267 if (valueType != napi_string) {
268 stringArray.clear();
269 return nullptr;
270 }
271 std::string str;
272 GetStringFromNAPI(env, value, str);
273 stringArray.push_back(str);
274 }
275 // create result code
276 napi_value result;
277 napi_status status = napi_create_int32(env, NAPI_RETURN_ONE, &result);
278 if (status != napi_ok) {
279 return nullptr;
280 }
281 return result;
282 }
283
ParseElementArray(napi_env env,std::vector<AppExecFwk::ElementName> & elementArray,napi_value args)284 napi_value ParseElementArray(napi_env env, std::vector<AppExecFwk::ElementName> &elementArray, napi_value args)
285 {
286 EDMLOGD("begin to parse element array");
287 bool isArray = false;
288 NAPI_CALL(env, napi_is_array(env, args, &isArray));
289 if (!isArray) {
290 EDMLOGE("napi object is not array.");
291 return nullptr;
292 }
293 uint32_t arrayLength = 0;
294 NAPI_CALL(env, napi_get_array_length(env, args, &arrayLength));
295 EDMLOGD("length=%{public}ud", arrayLength);
296 for (uint32_t j = 0; j < arrayLength; j++) {
297 napi_value value = nullptr;
298 NAPI_CALL(env, napi_get_element(env, args, j, &value));
299 napi_valuetype valueType = napi_undefined;
300 NAPI_CALL(env, napi_typeof(env, value, &valueType));
301 if (valueType != napi_object) {
302 elementArray.clear();
303 return nullptr;
304 }
305 AppExecFwk::ElementName element;
306 ParseElementName(env, element, value);
307 elementArray.push_back(element);
308 }
309 // create result code
310 napi_value result;
311 napi_status status = napi_create_int32(env, NAPI_RETURN_ONE, &result);
312 if (status != napi_ok) {
313 return nullptr;
314 }
315 return result;
316 }
317
JsObjectToInt(napi_env env,napi_value object,const char * filedStr,bool isNecessaryProp,int32_t & result)318 bool JsObjectToInt(napi_env env, napi_value object, const char *filedStr, bool isNecessaryProp, int32_t &result)
319 {
320 bool hasProperty = false;
321 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
322 EDMLOGE("get js property failed.");
323 return false;
324 }
325 if (isNecessaryProp && !hasProperty) {
326 return false;
327 }
328 if (hasProperty) {
329 napi_value prop = nullptr;
330 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok && ParseInt(env, result, prop);
331 }
332 return true;
333 }
334
JsObjectToUint(napi_env env,napi_value object,const char * filedStr,bool isNecessaryProp,uint32_t & result)335 bool JsObjectToUint(napi_env env, napi_value object, const char *filedStr, bool isNecessaryProp, uint32_t &result)
336 {
337 bool hasProperty = false;
338 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
339 EDMLOGE("get js property failed.");
340 return false;
341 }
342 if (isNecessaryProp && !hasProperty) {
343 return false;
344 }
345 if (hasProperty) {
346 napi_value prop = nullptr;
347 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok && ParseUint(env, result, prop);
348 }
349 return true;
350 }
351
JsObjectToLong(napi_env env,napi_value object,const char * filedStr,bool isNecessaryProp,int64_t & result)352 bool JsObjectToLong(napi_env env, napi_value object, const char *filedStr, bool isNecessaryProp, int64_t &result)
353 {
354 bool hasProperty = false;
355 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
356 EDMLOGE("get js property failed.");
357 return false;
358 }
359 if (isNecessaryProp && !hasProperty) {
360 return false;
361 }
362 if (hasProperty) {
363 napi_value prop = nullptr;
364 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok && ParseLong(env, result, prop);
365 }
366 return true;
367 }
368
JsObjectToBool(napi_env env,napi_value object,const char * filedStr,bool isNecessaryProp,bool & result)369 bool JsObjectToBool(napi_env env, napi_value object, const char *filedStr, bool isNecessaryProp, bool &result)
370 {
371 bool hasProperty = false;
372 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
373 EDMLOGE("get js property failed.");
374 return false;
375 }
376 if (isNecessaryProp && !hasProperty) {
377 return false;
378 }
379 if (hasProperty) {
380 napi_value prop = nullptr;
381 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok && ParseBool(env, result, prop);
382 }
383 return true;
384 }
385
JsObjectToString(napi_env env,napi_value object,const char * filedStr,bool isNecessaryProp,std::string & resultStr)386 bool JsObjectToString(napi_env env, napi_value object, const char *filedStr, bool isNecessaryProp,
387 std::string &resultStr)
388 {
389 bool hasProperty = false;
390 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
391 EDMLOGE("get js property failed.");
392 return false;
393 }
394 if (isNecessaryProp && !hasProperty) {
395 return false;
396 }
397 if (hasProperty) {
398 napi_value prop = nullptr;
399 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok && ParseString(env, resultStr, prop);
400 }
401 return true;
402 }
403
JsObjectToCharArray(napi_env env,napi_value object,const char * filedStr,std::tuple<int,bool> charArrayProp,std::vector<char> & ret)404 bool JsObjectToCharArray(napi_env env, napi_value object, const char *filedStr, std::tuple<int, bool> charArrayProp,
405 std::vector<char> &ret)
406 {
407 bool hasProperty = false;
408 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
409 EDMLOGE("get js property failed.");
410 return false;
411 }
412 int maxLength = 0;
413 bool isNecessaryProp = false;
414 std::tie(maxLength, isNecessaryProp) = charArrayProp;
415 if (isNecessaryProp && !hasProperty) {
416 return false;
417 }
418 if (hasProperty) {
419 napi_value prop = nullptr;
420 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok &&
421 ParseCharArray(env, prop, maxLength, ret);
422 }
423 return true;
424 }
425
GetJsProperty(napi_env env,napi_value object,const char * filedStr,napi_value & result)426 bool GetJsProperty(napi_env env, napi_value object, const char *filedStr, napi_value &result)
427 {
428 bool hasProperty = false;
429 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok || !hasProperty ||
430 napi_get_named_property(env, object, filedStr, &result) != napi_ok) {
431 EDMLOGE("Js has no property");
432 return false;
433 }
434 return true;
435 }
436
JsObjectToU8Vector(napi_env env,napi_value object,const char * fieldStr,std::vector<uint8_t> & certVector)437 bool JsObjectToU8Vector(napi_env env, napi_value object, const char *fieldStr, std::vector<uint8_t> &certVector)
438 {
439 napi_value certEntry;
440 if (!GetJsProperty(env, object, fieldStr, certEntry)) {
441 return false;
442 }
443 bool isTypedArray = false;
444 if (napi_is_typedarray(env, certEntry, &isTypedArray) != napi_ok || !isTypedArray) {
445 EDMLOGE("js property is not typedarray");
446 return false;
447 }
448 size_t length = 0;
449 size_t offset = 0;
450 napi_typedarray_type type;
451 napi_value buffer = nullptr;
452 void *data = nullptr;
453 if (napi_get_typedarray_info(env, certEntry, &type, &length, &data, &buffer, &offset) != napi_ok ||
454 type != napi_uint8_array || buffer == nullptr) {
455 EDMLOGE("js object type is not uint8 array");
456 return false;
457 }
458 if (length > NAPI_MAX_DATA_LEN) {
459 EDMLOGE("uint8 array range failed");
460 return false;
461 }
462 if (data == nullptr) {
463 EDMLOGE("uint8 array data failed");
464 return false;
465 }
466 certVector.clear();
467 certVector.assign(static_cast<uint8_t *>(data), (static_cast<uint8_t *>(data) + length));
468 return true;
469 }
470
JsObjectToStringVector(napi_env env,napi_value object,const char * filedStr,bool isNecessaryProp,std::vector<std::string> & vec)471 bool JsObjectToStringVector(napi_env env, napi_value object, const char *filedStr, bool isNecessaryProp,
472 std::vector<std::string> &vec)
473 {
474 bool hasProperty = false;
475 if (napi_has_named_property(env, object, filedStr, &hasProperty) != napi_ok) {
476 EDMLOGE("get js property failed.");
477 return false;
478 }
479 if (isNecessaryProp && !hasProperty) {
480 EDMLOGE("no yaobaohua hasProperty.");
481 return false;
482 }
483 if (hasProperty) {
484 napi_value prop = nullptr;
485 return napi_get_named_property(env, object, filedStr, &prop) == napi_ok && ParseStringArray(env, vec, prop);
486 }
487 return true;
488 }
489
NativeVoidCallbackComplete(napi_env env,napi_status status,void * data)490 void NativeVoidCallbackComplete(napi_env env, napi_status status, void *data)
491 {
492 if (data == nullptr) {
493 EDMLOGE("data is nullptr");
494 return;
495 }
496 AsyncCallbackInfo *asyncCallbackInfo = static_cast<AsyncCallbackInfo *>(data);
497 napi_value result = nullptr;
498 napi_get_null(env, &result);
499 NativeCallbackComplete(env, status, asyncCallbackInfo, result);
500 delete asyncCallbackInfo;
501 }
502
HandleAsyncWork(napi_env env,AsyncCallbackInfo * context,const std::string & workName,napi_async_execute_callback execute,napi_async_complete_callback complete)503 napi_value HandleAsyncWork(napi_env env, AsyncCallbackInfo *context, const std::string &workName,
504 napi_async_execute_callback execute, napi_async_complete_callback complete)
505 {
506 napi_value result = nullptr;
507 if (context->callback == nullptr) {
508 napi_create_promise(env, &context->deferred, &result);
509 } else {
510 napi_get_undefined(env, &result);
511 }
512 napi_value resource = nullptr;
513 napi_get_undefined(env, &resource);
514 napi_value resourceName = nullptr;
515 napi_create_string_utf8(env, workName.data(), NAPI_AUTO_LENGTH, &resourceName);
516 napi_create_async_work(env, resource, resourceName, execute, complete, static_cast<void *>(context),
517 &context->asyncWork);
518 napi_queue_async_work(env, context->asyncWork);
519 return result;
520 }
521
NativeBoolCallbackComplete(napi_env env,napi_status status,void * data)522 void NativeBoolCallbackComplete(napi_env env, napi_status status, void *data)
523 {
524 if (data == nullptr) {
525 EDMLOGE("data is nullptr");
526 return;
527 }
528 AsyncCallbackInfo *asyncCallbackInfo = static_cast<AsyncCallbackInfo *>(data);
529 napi_value result = nullptr;
530 napi_get_boolean(env, asyncCallbackInfo->boolRet, &result);
531 NativeCallbackComplete(env, status, asyncCallbackInfo, result);
532 delete asyncCallbackInfo;
533 }
534
NativeNumberCallbackComplete(napi_env env,napi_status status,void * data)535 void NativeNumberCallbackComplete(napi_env env, napi_status status, void *data)
536 {
537 if (data == nullptr) {
538 EDMLOGE("data is nullptr");
539 return;
540 }
541 AsyncCallbackInfo *asyncCallbackInfo = static_cast<AsyncCallbackInfo *>(data);
542 napi_value result = nullptr;
543 napi_create_int32(env, asyncCallbackInfo->intRet, &result);
544 NativeCallbackComplete(env, status, asyncCallbackInfo, result);
545 delete asyncCallbackInfo;
546 }
547
NativeStringCallbackComplete(napi_env env,napi_status status,void * data)548 void NativeStringCallbackComplete(napi_env env, napi_status status, void *data)
549 {
550 if (data == nullptr) {
551 EDMLOGE("data is nullptr");
552 return;
553 }
554 AsyncCallbackInfo *asyncCallbackInfo = static_cast<AsyncCallbackInfo *>(data);
555 napi_value result = nullptr;
556 napi_create_string_utf8(env, asyncCallbackInfo->stringRet.c_str(), NAPI_AUTO_LENGTH, &result);
557 NativeCallbackComplete(env, status, asyncCallbackInfo, result);
558 delete asyncCallbackInfo;
559 }
560
NativeArrayStringCallbackComplete(napi_env env,napi_status status,void * data)561 void NativeArrayStringCallbackComplete(napi_env env, napi_status status, void *data)
562 {
563 if (data == nullptr) {
564 EDMLOGE("data is nullptr");
565 return;
566 }
567 AsyncCallbackInfo *asyncCallbackInfo = static_cast<AsyncCallbackInfo *>(data);
568 napi_value result = nullptr;
569 napi_create_array(env, &result);
570 ConvertStringVectorToJS(env, asyncCallbackInfo->arrayStringRet, result);
571 NativeCallbackComplete(env, status, asyncCallbackInfo, result);
572 delete asyncCallbackInfo;
573 }
574
ConvertStringVectorToJS(napi_env env,const std::vector<std::string> & stringVector,napi_value result)575 void ConvertStringVectorToJS(napi_env env, const std::vector<std::string> &stringVector, napi_value result)
576 {
577 EDMLOGD("vector size: %{public}zu", stringVector.size());
578 size_t idx = 0;
579 for (const auto &str : stringVector) {
580 napi_value obj = nullptr;
581 napi_create_string_utf8(env, str.c_str(), NAPI_AUTO_LENGTH, &obj);
582 napi_set_element(env, result, idx, obj);
583 idx++;
584 }
585 }
586
CheckAdminWithUserIdParamType(napi_env env,size_t argc,napi_value * argv,bool & hasCallback,bool & hasUserId)587 bool CheckAdminWithUserIdParamType(napi_env env, size_t argc, napi_value *argv, bool &hasCallback, bool &hasUserId)
588 {
589 if (!MatchValueType(env, argv[ARR_INDEX_ZERO], napi_object)) {
590 EDMLOGE("CheckAdminWithUserIdParamType admin type check failed");
591 return false;
592 }
593 EDMLOGI("argc = %{public}zu", argc);
594 if (argc == ARGS_SIZE_ONE) {
595 hasCallback = false;
596 hasUserId = false;
597 EDMLOGI("hasCallback = false; hasUserId = false;");
598 return true;
599 }
600
601 if (argc == ARGS_SIZE_TWO) {
602 if (MatchValueType(env, argv[ARR_INDEX_ONE], napi_function)) {
603 hasCallback = true;
604 hasUserId = false;
605 EDMLOGI("hasCallback = true; hasUserId = false;");
606 return true;
607 } else {
608 hasCallback = false;
609 hasUserId = true;
610 EDMLOGI("hasCallback = false; hasUserId = true;");
611 return MatchValueType(env, argv[ARR_INDEX_ONE], napi_number);
612 }
613 }
614 hasCallback = true;
615 hasUserId = true;
616 EDMLOGI("hasCallback = true; hasUserId = true;");
617 return MatchValueType(env, argv[ARR_INDEX_ONE], napi_number) &&
618 MatchValueType(env, argv[ARR_INDEX_TWO], napi_function);
619 }
620
CheckGetPolicyAdminParam(napi_env env,napi_value value,bool & hasAdmin,OHOS::AppExecFwk::ElementName & elementName)621 bool CheckGetPolicyAdminParam(napi_env env, napi_value value, bool &hasAdmin,
622 OHOS::AppExecFwk::ElementName &elementName)
623 {
624 if (MatchValueType(env, value, napi_null)) {
625 hasAdmin = false;
626 return true;
627 }
628 if (MatchValueType(env, value, napi_object)) {
629 hasAdmin = true;
630 if (ParseElementName(env, elementName, value)) {
631 return true;
632 }
633 }
634 return false;
635 }
636
ParseStringToInt(const std::string & strValue,int32_t & result)637 bool ParseStringToInt(const std::string &strValue, int32_t &result)
638 {
639 int64_t temp = 0;
640 if (!ParseStringToLong(strValue, temp)) {
641 EDMLOGE("ParseStringToInt: parse str failed");
642 return false;
643 }
644 if (temp < INT_MIN || temp > INT_MAX) {
645 EDMLOGE("ParseStringToInt: parse failed, int32 expected.");
646 return false;
647 }
648 result = temp;
649 return true;
650 }
651
ParseStringToLong(const std::string & strValue,int64_t & result)652 bool ParseStringToLong(const std::string &strValue, int64_t &result)
653 {
654 char *end = nullptr;
655 const char *p = strValue.c_str();
656 errno = 0;
657 result = strtoll(p, &end, EdmConstants::DECIMAL);
658 if (errno == ERANGE || end == p || *end != '\0') {
659 EDMLOGE("ParseStringToLong: parse str failed: %{public}s", p);
660 return false;
661 }
662 return true;
663 }
664 } // namespace EDM
665 } // namespace OHOS