/* * 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 #include #include "sign_tool_service_impl.h" #include #include "options.h" #include "cert_tools.h" #include "params_run_tool.h" #include "localization_adapter.h" namespace OHOS { namespace SignatureTools { bool DoSomethingInterestingWithMyAPI(const uint8_t* data, size_t size) { if (!data || !size) { return true; } std::shared_ptr api = std::make_shared(); std::shared_ptr params = std::make_shared(); std::string keyAlias = "oh-app1-key-v1"; std::string issuerKeyAlias = "oh-app-sign-srv-ca-key-v1"; std::string keyUsage = "digitalSignature"; std::string extKeyUsage = "codeSignature"; std::string issuer = "C=CN,O=OpenHarmony,OU=OpenHarmony Community,CN= Application Signature Service CA"; std::string keyAlg = "ECC"; std::string subject = "C=CN,O=OpenHarmony,OU=OpenHarmony Community,CN=Root CA"; std::string signAlg = "SHA256withECDSA"; int basicConstraintsPathLen = 0; std::string keystoreFile = "/data/test/generateCA/OpenHarmony.p12"; int validity = 365; int keySize = 384; char keyPwd[] = "123456"; char ksPwd[] = "123456"; bool extKeyUsageCritical = true; std::string basicConstraints = "true"; std::string basicConstraintsCritical = "true"; std::string basicConstraintsCa = "true"; std::string outFile = "/data/test/generateCA/single-app1.cer"; (*params)["keyPwd"] = keyPwd; (*params)["issuer"] = issuer; (*params)["keystorePwd"] = ksPwd; (*params)["keyAlias"] = keyAlias; (*params)["issuerKeyAlias"] = issuerKeyAlias; (*params)["keyUsage"] = keyUsage; (*params)["extKeyUsage"] = extKeyUsage; (*params)["keyAlg"] = keyAlg; (*params)["keySize"] = keySize; (*params)["subject"] = subject; (*params)["signAlg"] = signAlg; (*params)["keystoreFile"] = keystoreFile; (*params)["basicConstraintsPathLen"] = basicConstraintsPathLen; (*params)["outFile"] = outFile; (*params)["validity"] = validity; (*params)["basicConstraints"] = basicConstraints; (*params)["basicConstraintsCritical"] = basicConstraintsCritical; (*params)["basicConstraintsCa"] = basicConstraintsCa; (*params)["extKeyUsageCritical"] = extKeyUsageCritical; return api->GenerateCert(params.get()); } } } /* Fuzzer entry point */ extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { /* Run your code on data */ OHOS::SignatureTools::DoSomethingInterestingWithMyAPI(data, size); return 0; }