14a616216Sopenharmony_ci/* 24a616216Sopenharmony_ci * Copyright (C) 2024 Huawei Device Co., Ltd. 34a616216Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 44a616216Sopenharmony_ci * you may not use this file except in compliance with the License. 54a616216Sopenharmony_ci * You may obtain a copy of the License at 64a616216Sopenharmony_ci * 74a616216Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 84a616216Sopenharmony_ci * 94a616216Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 104a616216Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 114a616216Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 124a616216Sopenharmony_ci * See the License for the specific language governing permissions and 134a616216Sopenharmony_ci * limitations under the License. 144a616216Sopenharmony_ci */ 154a616216Sopenharmony_ci 164a616216Sopenharmony_ci#include "devslinfoadpt_fuzzer.h" 174a616216Sopenharmony_ci 184a616216Sopenharmony_ci#include <cstddef> 194a616216Sopenharmony_ci#include <cstdint> 204a616216Sopenharmony_ci 214a616216Sopenharmony_ci#include "file_ex.h" 224a616216Sopenharmony_ci#include "securec.h" 234a616216Sopenharmony_ci#include "parameter.h" 244a616216Sopenharmony_ci#include "nativetoken_kit.h" 254a616216Sopenharmony_ci#include "token_setproc.h" 264a616216Sopenharmony_ci#include "accesstoken_kit.h" 274a616216Sopenharmony_ci 284a616216Sopenharmony_ci#include "dev_slinfo_adpt.h" 294a616216Sopenharmony_ci#include "dev_slinfo_mgr.h" 304a616216Sopenharmony_ci 314a616216Sopenharmony_cinamespace OHOS { 324a616216Sopenharmony_cistatic bool g_isForcingFuzz3 = false; 334a616216Sopenharmony_ci 344a616216Sopenharmony_cistatic uint8_t g_udidInvalid[MAX_UDID_LENGTH + 1] = "FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"; 354a616216Sopenharmony_ci 364a616216Sopenharmony_cistruct DeviceSecurityInfo { 374a616216Sopenharmony_ci uint32_t magicNum {0}; 384a616216Sopenharmony_ci uint32_t result {0}; 394a616216Sopenharmony_ci uint32_t level {0}; 404a616216Sopenharmony_ci}; 414a616216Sopenharmony_ci 424a616216Sopenharmony_ciextern "C" { 434a616216Sopenharmony_ci extern void OnApiDeviceSecInfoCallback(const DeviceIdentify *identify, struct DeviceSecurityInfo *info); 444a616216Sopenharmony_ci} 454a616216Sopenharmony_ci 464a616216Sopenharmony_cistatic void NativeTokenGetFuzz3(void) 474a616216Sopenharmony_ci{ 484a616216Sopenharmony_ci uint64_t tokenId3; 494a616216Sopenharmony_ci const char **permsFuzz3 = new const char *[1]; 504a616216Sopenharmony_ci permsFuzz3[0] = "ohos.permission.DISTRIBUTED_DATASYNC"; 514a616216Sopenharmony_ci NativeTokenInfoParams infoInstanceFuzz1 = { 524a616216Sopenharmony_ci .dcapsNum = 0, 534a616216Sopenharmony_ci .permsNum = 1, 544a616216Sopenharmony_ci .aclsNum = 0, 554a616216Sopenharmony_ci .dcaps = nullptr, 564a616216Sopenharmony_ci .perms = permsFuzz3, 574a616216Sopenharmony_ci .acls = nullptr, 584a616216Sopenharmony_ci .aplStr = "system_basic", 594a616216Sopenharmony_ci }; 604a616216Sopenharmony_ci 614a616216Sopenharmony_ci infoInstanceFuzz1.processName = "DevSLMgrTest"; 624a616216Sopenharmony_ci tokenId3 = GetAccessTokenId(&infoInstanceFuzz1); 634a616216Sopenharmony_ci SetSelfTokenID(tokenId3); 644a616216Sopenharmony_ci OHOS::Security::AccessToken::AccessTokenKit::ReloadNativeTokenInfo(); 654a616216Sopenharmony_ci delete[] permsFuzz3; 664a616216Sopenharmony_ci} 674a616216Sopenharmony_ci 684a616216Sopenharmony_cistatic void BeginFuzzCase3(void) 694a616216Sopenharmony_ci{ 704a616216Sopenharmony_ci std::string isEnforcing; 714a616216Sopenharmony_ci OHOS::LoadStringFromFile("/sys/fs/selinux/enforce", isEnforcing); 724a616216Sopenharmony_ci if (isEnforcing.compare("1") == 0) { 734a616216Sopenharmony_ci g_isForcingFuzz3 = true; 744a616216Sopenharmony_ci OHOS::SaveStringToFile("/sys/fs/selinux/enforce", "0"); 754a616216Sopenharmony_ci } 764a616216Sopenharmony_ci NativeTokenGetFuzz3(); 774a616216Sopenharmony_ci} 784a616216Sopenharmony_ci 794a616216Sopenharmony_cistatic void EndFuzzCase3(void) 804a616216Sopenharmony_ci{ 814a616216Sopenharmony_ci if (g_isForcingFuzz3) { 824a616216Sopenharmony_ci OHOS::SaveStringToFile("/sys/fs/selinux/enforce", "1"); 834a616216Sopenharmony_ci } 844a616216Sopenharmony_ci} 854a616216Sopenharmony_ci 864a616216Sopenharmony_cistatic int32_t GetLocalUdidFuzz3(DEVSLQueryParams *queryParams) 874a616216Sopenharmony_ci{ 884a616216Sopenharmony_ci char udid[MAX_UDID_LENGTH + 1] = {0}; 894a616216Sopenharmony_ci int32_t ret = GetDevUdid(udid, MAX_UDID_LENGTH + 1); 904a616216Sopenharmony_ci if (ret != DEVSL_SUCCESS) { 914a616216Sopenharmony_ci return DEVSL_ERROR; 924a616216Sopenharmony_ci } 934a616216Sopenharmony_ci 944a616216Sopenharmony_ci (void)memcpy_s(queryParams->udid, MAX_UDID_LENGTH, udid, MAX_UDID_LENGTH); 954a616216Sopenharmony_ci queryParams->udidLen = MAX_UDID_LENGTH; 964a616216Sopenharmony_ci return ret; 974a616216Sopenharmony_ci} 984a616216Sopenharmony_ci 994a616216Sopenharmony_civoid FuzzDoDevSlinfoAdpt(const uint8_t* data, size_t size) 1004a616216Sopenharmony_ci{ 1014a616216Sopenharmony_ci if (data == nullptr || size <= MAX_UDID_LENGTH) { 1024a616216Sopenharmony_ci return; 1034a616216Sopenharmony_ci } 1044a616216Sopenharmony_ci OnApiDeviceSecInfoCallback(nullptr, nullptr); 1054a616216Sopenharmony_ci (void)GetDeviceSecLevelByUdidAsync(nullptr, 0); 1064a616216Sopenharmony_ci 1074a616216Sopenharmony_ci DEVSLQueryParams queryParams; 1084a616216Sopenharmony_ci (void)memset_s(&queryParams, sizeof(DEVSLQueryParams), 0, sizeof(DEVSLQueryParams)); 1094a616216Sopenharmony_ci queryParams.udidLen = MAX_UDID_LENGTH; 1104a616216Sopenharmony_ci (void)memcpy_s(queryParams.udid, MAX_UDID_LENGTH, data, MAX_UDID_LENGTH); 1114a616216Sopenharmony_ci BeginFuzzCase3(); 1124a616216Sopenharmony_ci uint32_t levelInfo = 0; 1134a616216Sopenharmony_ci int32_t devLevel = 0; 1144a616216Sopenharmony_ci DeviceIdentify devId; 1154a616216Sopenharmony_ci DeviceSecurityInfo devInfo; 1164a616216Sopenharmony_ci (void)DATASL_OnStart(); 1174a616216Sopenharmony_ci 1184a616216Sopenharmony_ci do { 1194a616216Sopenharmony_ci int32_t ret = GetLocalUdidFuzz3(&queryParams); 1204a616216Sopenharmony_ci if (ret != DEVSL_SUCCESS) { 1214a616216Sopenharmony_ci break; 1224a616216Sopenharmony_ci } 1234a616216Sopenharmony_ci ret = GetDeviceSecLevelByUdid(static_cast<const uint8_t *>(g_udidInvalid), MAX_UDID_LENGTH + 1, &devLevel); 1244a616216Sopenharmony_ci if (ret == DEVSL_SUCCESS) { 1254a616216Sopenharmony_ci break; 1264a616216Sopenharmony_ci } 1274a616216Sopenharmony_ci (void)GetDeviceSecLevelByUdid(static_cast<const uint8_t *>(queryParams.udid), queryParams.udidLen, &devLevel); 1284a616216Sopenharmony_ci (void)DATASL_GetHighestSecLevel(&queryParams, &levelInfo); 1294a616216Sopenharmony_ci 1304a616216Sopenharmony_ci (void)memset_s(&devId, sizeof(devId), 0, sizeof(devId)); 1314a616216Sopenharmony_ci (void)memcpy_s(devId.identity, MAX_UDID_LENGTH, queryParams.udid, queryParams.udidLen); 1324a616216Sopenharmony_ci devId.length = queryParams.udidLen; 1334a616216Sopenharmony_ci 1344a616216Sopenharmony_ci OnApiDeviceSecInfoCallback(&devId, nullptr); 1354a616216Sopenharmony_ci OnApiDeviceSecInfoCallback(&devId, &devInfo); 1364a616216Sopenharmony_ci } while (0); 1374a616216Sopenharmony_ci DATASL_OnStop(); 1384a616216Sopenharmony_ci EndFuzzCase3(); 1394a616216Sopenharmony_ci} 1404a616216Sopenharmony_ci} 1414a616216Sopenharmony_ci 1424a616216Sopenharmony_ci/* Fuzzer entry point */ 1434a616216Sopenharmony_ciextern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) 1444a616216Sopenharmony_ci{ 1454a616216Sopenharmony_ci /* Run your code on data */ 1464a616216Sopenharmony_ci OHOS::FuzzDoDevSlinfoAdpt(data, size); 1474a616216Sopenharmony_ci return 0; 1484a616216Sopenharmony_ci}