• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 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 <cstddef>
17 #include <cstdint>
18 #include <cstdio>
19 #include <cstring>
20 
21 #include "sign_tool_service_impl.h"
22 #include <openssl/ssl.h>
23 #include "options.h"
24 #include "cert_tools.h"
25 #include "params_run_tool.h"
26 #include "localization_adapter.h"
27 
28 
29 namespace OHOS {
30 namespace SignatureTools {
DoSomethingInterestingWithMyAPI(const uint8_t * data,size_t size)31 bool DoSomethingInterestingWithMyAPI(const uint8_t* data, size_t size)
32 {
33     if (!data || !size) {
34         return true;
35     }
36 
37     std::shared_ptr<SignToolServiceImpl> api = std::make_shared<SignToolServiceImpl>();
38     std::shared_ptr<Options> params = std::make_shared<Options>();
39     std::string keyAlias = "oh-app-sign-srv-ca-key-v1";
40     std::string issuerKeyAlias = "oh-root-ca-key-v1";
41     std::string issuer = "C=CN,O=OpenHarmony,OU=OpenHarmony Community,CN=Root CA";
42     std::string subject = std::string(reinterpret_cast<const char*>(data), size);
43     std::string signAlg = "SHA384withECDSA";
44     int basicConstraintsPathLen = 0;
45     std::string keyAlg = "ECC";
46     std::string keystoreFile = "/data/test/generateCA/OpenHarmony.p12";
47     int validity = 365;
48     int keySize = 384;
49     char keyPwd[] = "123456";
50     char ksPwd[] = "123456";
51     char issuerkeyPwd[] = "123456";
52     std::string outFile = "/data/test/generateCA/app-sign-srv-ca1.cer";
53     (*params)["keyPwd"] = keyPwd;
54     (*params)["issuer"] = issuer;
55     (*params)["issuerKeyPwd"] = issuerkeyPwd;
56     (*params)["keystorePwd"] = ksPwd;
57     (*params)["keyAlias"] = keyAlias;
58     (*params)["issuerKeyAlias"] = issuerKeyAlias;
59     (*params)["keySize"] = keySize;
60     (*params)["subject"] = subject;
61     (*params)["keyAlg"] = keyAlg;
62     (*params)["signAlg"] = signAlg;
63     (*params)["keystoreFile"] = keystoreFile;
64     (*params)["basicConstraintsPathLen"] = basicConstraintsPathLen;
65     (*params)["outFile"] = outFile;
66     (*params)["validity"] = validity;
67     return api->GenerateCA(params.get());
68 }
69 }
70 }
71 
72 /* Fuzzer entry point */
LLVMFuzzerTestOneInput(const uint8_t * data,size_t size)73 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
74 {
75     /* Run your code on data */
76     OHOS::SignatureTools::DoSomethingInterestingWithMyAPI(data, size);
77     return 0;
78 }