1e5d0e473Sopenharmony_ci/* 2e5d0e473Sopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd. 3e5d0e473Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4e5d0e473Sopenharmony_ci * you may not use this file except in compliance with the License. 5e5d0e473Sopenharmony_ci * You may obtain a copy of the License at 6e5d0e473Sopenharmony_ci * 7e5d0e473Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8e5d0e473Sopenharmony_ci * 9e5d0e473Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10e5d0e473Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11e5d0e473Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12e5d0e473Sopenharmony_ci * See the License for the specific language governing permissions and 13e5d0e473Sopenharmony_ci * limitations under the License. 14e5d0e473Sopenharmony_ci */ 15e5d0e473Sopenharmony_ci 16e5d0e473Sopenharmony_ci#include "updatesimmessage_fuzzer.h" 17e5d0e473Sopenharmony_ci 18e5d0e473Sopenharmony_ci#define private public 19e5d0e473Sopenharmony_ci#include "addsmstoken_fuzzer.h" 20e5d0e473Sopenharmony_ci#include "core_manager_inner.h" 21e5d0e473Sopenharmony_ci#include "i_sms_service_interface.h" 22e5d0e473Sopenharmony_ci#include "sms_service.h" 23e5d0e473Sopenharmony_ci 24e5d0e473Sopenharmony_ciusing namespace OHOS::Telephony; 25e5d0e473Sopenharmony_cinamespace OHOS { 26e5d0e473Sopenharmony_cistatic bool g_isInited = false; 27e5d0e473Sopenharmony_ciconstexpr int32_t SLOT_NUM = 2; 28e5d0e473Sopenharmony_ciconstexpr int32_t SIM_MESSAGE_STATUE = 4; 29e5d0e473Sopenharmony_ci 30e5d0e473Sopenharmony_cibool IsServiceInited() 31e5d0e473Sopenharmony_ci{ 32e5d0e473Sopenharmony_ci if (!g_isInited) { 33e5d0e473Sopenharmony_ci CoreManagerInner::GetInstance().isInitAllObj_ = true; 34e5d0e473Sopenharmony_ci DelayedSingleton<SmsService>::GetInstance()->registerToService_ = true; 35e5d0e473Sopenharmony_ci DelayedSingleton<SmsService>::GetInstance()->WaitCoreServiceToInit(); 36e5d0e473Sopenharmony_ci DelayedSingleton<SmsService>::GetInstance()->OnStart(); 37e5d0e473Sopenharmony_ci if (DelayedSingleton<SmsService>::GetInstance()->GetServiceRunningState() == 38e5d0e473Sopenharmony_ci static_cast<int32_t>(Telephony::ServiceRunningState::STATE_RUNNING)) { 39e5d0e473Sopenharmony_ci g_isInited = true; 40e5d0e473Sopenharmony_ci } 41e5d0e473Sopenharmony_ci } 42e5d0e473Sopenharmony_ci return g_isInited; 43e5d0e473Sopenharmony_ci} 44e5d0e473Sopenharmony_ci 45e5d0e473Sopenharmony_civoid UpdateSimMessage(const uint8_t *data, size_t size) 46e5d0e473Sopenharmony_ci{ 47e5d0e473Sopenharmony_ci if (!IsServiceInited()) { 48e5d0e473Sopenharmony_ci return; 49e5d0e473Sopenharmony_ci } 50e5d0e473Sopenharmony_ci 51e5d0e473Sopenharmony_ci MessageParcel dataParcel; 52e5d0e473Sopenharmony_ci MessageParcel replyParcel; 53e5d0e473Sopenharmony_ci MessageOption option(MessageOption::TF_SYNC); 54e5d0e473Sopenharmony_ci 55e5d0e473Sopenharmony_ci std::string smsc(reinterpret_cast<const char *>(data), size); 56e5d0e473Sopenharmony_ci std::string pdu(reinterpret_cast<const char *>(data), size); 57e5d0e473Sopenharmony_ci auto smscU16 = Str8ToStr16(smsc); 58e5d0e473Sopenharmony_ci auto pduU16 = Str8ToStr16(pdu); 59e5d0e473Sopenharmony_ci int32_t slotId = static_cast<int32_t>(size % SLOT_NUM); 60e5d0e473Sopenharmony_ci ISmsServiceInterface::SimMessageStatus status = 61e5d0e473Sopenharmony_ci static_cast<ISmsServiceInterface::SimMessageStatus>(size % SIM_MESSAGE_STATUE); 62e5d0e473Sopenharmony_ci 63e5d0e473Sopenharmony_ci dataParcel.WriteInt32(slotId); 64e5d0e473Sopenharmony_ci dataParcel.WriteUint32(size); 65e5d0e473Sopenharmony_ci dataParcel.WriteUint32(status); 66e5d0e473Sopenharmony_ci dataParcel.WriteString16(smscU16); 67e5d0e473Sopenharmony_ci dataParcel.WriteString16(pduU16); 68e5d0e473Sopenharmony_ci dataParcel.RewindRead(0); 69e5d0e473Sopenharmony_ci 70e5d0e473Sopenharmony_ci DelayedSingleton<SmsService>::GetInstance()->OnUpdateSimMessage(dataParcel, replyParcel, option); 71e5d0e473Sopenharmony_ci 72e5d0e473Sopenharmony_ci std::shared_ptr<SmsInterfaceManager> interfaceManager = std::make_shared<SmsInterfaceManager>(slotId); 73e5d0e473Sopenharmony_ci if (interfaceManager == nullptr) { 74e5d0e473Sopenharmony_ci TELEPHONY_LOGE("interfaceManager nullptr error"); 75e5d0e473Sopenharmony_ci return; 76e5d0e473Sopenharmony_ci } 77e5d0e473Sopenharmony_ci interfaceManager->InitInterfaceManager(); 78e5d0e473Sopenharmony_ci interfaceManager->UpdateSimMessage(size, status, pdu, smsc); 79e5d0e473Sopenharmony_ci 80e5d0e473Sopenharmony_ci std::shared_ptr<SmsMiscManager> smsMiscManager = std::make_shared<SmsMiscManager>(slotId); 81e5d0e473Sopenharmony_ci if (smsMiscManager == nullptr) { 82e5d0e473Sopenharmony_ci TELEPHONY_LOGE("smsMiscManager nullptr error"); 83e5d0e473Sopenharmony_ci return; 84e5d0e473Sopenharmony_ci } 85e5d0e473Sopenharmony_ci smsMiscManager->UpdateSimMessage(size, status, pdu, smsc); 86e5d0e473Sopenharmony_ci} 87e5d0e473Sopenharmony_ci 88e5d0e473Sopenharmony_civoid DoSomethingInterestingWithMyAPI(const uint8_t *data, size_t size) 89e5d0e473Sopenharmony_ci{ 90e5d0e473Sopenharmony_ci if (data == nullptr || size == 0) { 91e5d0e473Sopenharmony_ci return; 92e5d0e473Sopenharmony_ci } 93e5d0e473Sopenharmony_ci 94e5d0e473Sopenharmony_ci UpdateSimMessage(data, size); 95e5d0e473Sopenharmony_ci DelayedSingleton<SmsService>::DestroyInstance(); 96e5d0e473Sopenharmony_ci} 97e5d0e473Sopenharmony_ci} // namespace OHOS 98e5d0e473Sopenharmony_ci 99e5d0e473Sopenharmony_ci/* Fuzzer entry point */ 100e5d0e473Sopenharmony_ciextern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) 101e5d0e473Sopenharmony_ci{ 102e5d0e473Sopenharmony_ci /* Run your code on data */ 103e5d0e473Sopenharmony_ci OHOS::AddSmsTokenFuzzer token; 104e5d0e473Sopenharmony_ci OHOS::DoSomethingInterestingWithMyAPI(data, size); 105e5d0e473Sopenharmony_ci return 0; 106e5d0e473Sopenharmony_ci} 107