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 }