1d9f0492fSopenharmony_ci/*
2d9f0492fSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
3d9f0492fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4d9f0492fSopenharmony_ci * you may not use this file except in compliance with the License.
5d9f0492fSopenharmony_ci * You may obtain a copy of the License at
6d9f0492fSopenharmony_ci *
7d9f0492fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
8d9f0492fSopenharmony_ci *
9d9f0492fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10d9f0492fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11d9f0492fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12d9f0492fSopenharmony_ci * See the License for the specific language governing permissions and
13d9f0492fSopenharmony_ci * limitations under the License.
14d9f0492fSopenharmony_ci */
15d9f0492fSopenharmony_ci
16d9f0492fSopenharmony_ci#include "getdevicenodepermissions_fuzzer.h"
17d9f0492fSopenharmony_ci#include <string>
18d9f0492fSopenharmony_ci#include "ueventd_read_cfg.h"
19d9f0492fSopenharmony_ci
20d9f0492fSopenharmony_cinamespace OHOS {
21d9f0492fSopenharmony_ci    bool FuzzGetDeviceNodePermissions(const uint8_t* data, size_t size)
22d9f0492fSopenharmony_ci    {
23d9f0492fSopenharmony_ci        if ((data == nullptr) || (size < sizeof(char) + sizeof(uid_t) + sizeof(gid_t) + sizeof(mode_t))) {
24d9f0492fSopenharmony_ci            return false;
25d9f0492fSopenharmony_ci        }
26d9f0492fSopenharmony_ci        bool result = false;
27d9f0492fSopenharmony_ci        unsigned int offset = 0;
28d9f0492fSopenharmony_ci        const char *devNode = reinterpret_cast<const char*>(data + offset);
29d9f0492fSopenharmony_ci        offset += sizeof(char);
30d9f0492fSopenharmony_ci        uid_t *uid = reinterpret_cast<uid_t*>(const_cast<uint8_t *>(data + offset));
31d9f0492fSopenharmony_ci        offset += sizeof(uid_t);
32d9f0492fSopenharmony_ci        gid_t *gid = reinterpret_cast<gid_t*>(const_cast<uint8_t *>(data + offset));
33d9f0492fSopenharmony_ci        offset += sizeof(gid_t);
34d9f0492fSopenharmony_ci        mode_t *mode = reinterpret_cast<mode_t*>(const_cast<uint8_t *>(data + offset));
35d9f0492fSopenharmony_ci        if (GetDeviceNodePermissions(devNode, uid, gid, mode) != 0) {
36d9f0492fSopenharmony_ci            result = true;
37d9f0492fSopenharmony_ci        };
38d9f0492fSopenharmony_ci        return result;
39d9f0492fSopenharmony_ci    }
40d9f0492fSopenharmony_ci}
41d9f0492fSopenharmony_ci
42d9f0492fSopenharmony_ci/* Fuzzer entry point */
43d9f0492fSopenharmony_ciextern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
44d9f0492fSopenharmony_ci{
45d9f0492fSopenharmony_ci    /* Run your code on data */
46d9f0492fSopenharmony_ci    OHOS::FuzzGetDeviceNodePermissions(data, size);
47d9f0492fSopenharmony_ci    return 0;
48d9f0492fSopenharmony_ci}