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 "params_run_tool.h"
20 
21 namespace OHOS {
22 namespace SignatureTools {
DoSomethingInterestingWithMyAPI(const uint8_t* data, size_t size)23 bool DoSomethingInterestingWithMyAPI(const uint8_t* data, size_t size)
24 {
25     if (!data || !size) {
26         return true;
27     }
28 
29     char arg0[] = "";
30     char arg1[] = "generate-app-cert";
31     char arg2[] = "-keyAlias";
32     char arg3[] = "oh-app1-key-v1";
33     char arg4[] = "-keyPwd";
34     char arg5[] = "123456";
35     char arg6[] = "-issuer";
36     char arg7[] = "C=CN;O=OpenHarmony;OU=OpenHarmony Community;CN=Application Signature Service CA";
37     char arg8[] = "-issuerKeyAlias";
38     char arg9[] = "oh-app-sign-srv-ca-key-v1";
39     char arg10[] = "-subject";
40     char arg11[] = "C=CN;O=OpenHarmony;OU=OpenHarmony Community;CN=App1 Release";
41     char arg12[] = "-validity";
42     char arg13[] = "365";
43     char arg14[] = "-signAlg";
44     char arg15[] = "SHA256withECDSA";
45     char arg16[] = "-keystoreFile";
46     char arg17[] = "./generateKeyPair/OpenHarmony.p12";
47     char arg18[] = "-keystorePwd";
48     char arg19[] = "123456";
49     char arg20[] = "-outFile";
50     char arg21[] = "./generateKeyPair/app1.cer";
51     char arg22[] = "-subCaCertFile";
52     char arg23[] = "./generateKeyPair/app-sign-srv-ca1.cer";
53     char arg24[] = "-outForm";
54     char arg25[] = "certChain";
55     char arg26[] = "-rootCaCertFile";
56     char arg27[] = "./generateKeyPair/root-ca1.cer";
57     char arg28[] = "-issuerKeyPwd";
58     char arg29[] = "123456";
59     char* argv[] = { arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9, arg10, arg11, arg12,
60                      arg13, arg14, arg15, arg16, arg17, arg18, arg19, arg20, arg21,
61                      arg22, arg23, arg24, arg25, arg26, arg27, arg28, arg29 };
62     int argc = 30;
63 
64     bool ret = ParamsRunTool::ProcessCmd(argv, argc);
65     return ret;
66 }
67 } // namespace SignatureTools
68 } // namespace OHOS
69 
70 /* Fuzzer entry point */
LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)71 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
72 {
73     /* Run your code on data */
74     OHOS::SignatureTools::DoSomethingInterestingWithMyAPI(data, size);
75     return 0;
76 }