/* * Copyright (c) 2024 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include "securec.h" #include "napi/native_api.h" #include "napi/native_node_api.h" #include "asset_log.h" #include "asset_mem.h" #include "asset_system_api.h" #include "asset_system_type.h" #include "asset_napi_check.h" #include "asset_napi_common.h" #include "asset_napi_pre_query.h" namespace OHOS { namespace Security { namespace Asset { namespace { const std::vector OPTIONAL_TAGS = { SEC_ASSET_TAG_AUTH_VALIDITY_PERIOD }; napi_status CheckPreQueryArgs(const napi_env env, const std::vector &attrs) { std::vector validTags; validTags.insert(validTags.end(), CRITICAL_LABEL_TAGS.begin(), CRITICAL_LABEL_TAGS.end()); validTags.insert(validTags.end(), NORMAL_LABEL_TAGS.begin(), NORMAL_LABEL_TAGS.end()); validTags.insert(validTags.end(), NORMAL_LOCAL_LABEL_TAGS.begin(), NORMAL_LOCAL_LABEL_TAGS.end()); validTags.insert(validTags.end(), ACCESS_CONTROL_TAGS.begin(), ACCESS_CONTROL_TAGS.end()); validTags.insert(validTags.end(), OPTIONAL_TAGS.begin(), OPTIONAL_TAGS.end()); IF_FALSE_RETURN(CheckAssetTagValidity(env, attrs, validTags), napi_invalid_arg); IF_FALSE_RETURN(CheckAssetValueValidity(env, attrs), napi_invalid_arg); return napi_ok; } } // anonymous namespace napi_value NapiPreQuery(const napi_env env, napi_callback_info info, const NapiCallerArgs &args) { napi_async_execute_callback execute = [](napi_env env, void *data) { AsyncContext *context = static_cast(data); context->result = AssetPreQuery(&context->attrs[0], context->attrs.size(), &context->challenge); }; return NapiAsync(env, info, execute, args, &CheckPreQueryArgs); } napi_value NapiPreQuery(const napi_env env, napi_callback_info info) { NapiCallerArgs args = { .expectArgNum = NORMAL_ARGS_NUM, .isUpdate = false, .isAsUser = false }; return NapiPreQuery(env, info, args); } napi_value NapiPreQueryAsUser(const napi_env env, napi_callback_info info) { NapiCallerArgs args = { .expectArgNum = AS_USER_ARGS_NUM, .isUpdate = false, .isAsUser = true }; return NapiPreQuery(env, info, args); } napi_value NapiPreQuerySync(const napi_env env, napi_callback_info info) { std::vector attrs; AssetBlob challenge = { 0 }; napi_value result = nullptr; NapiCallerArgs args = { .expectArgNum = NORMAL_ARGS_NUM, .isUpdate = false, .isAsUser = false }; do { if (ParseParam(env, info, args, attrs) != napi_ok) { break; } if (CheckPreQueryArgs(env, attrs) != napi_ok) { break; } int32_t res = AssetPreQuery(&attrs[0], attrs.size(), &challenge); CHECK_RESULT_BREAK(env, res); result = CreateJsUint8Array(env, challenge); } while (false); AssetFreeBlob(&challenge); FreeAssetAttrs(attrs); return result; } } // Asset } // Security } // OHOS