1a196e50eSopenharmony_ci<?xml version="1.0" encoding="UTF-8"?>
2a196e50eSopenharmony_ci<!-- Copyright (c) 2021 Huawei Device Co., Ltd.
3a196e50eSopenharmony_ci
4a196e50eSopenharmony_ci     Licensed under the Apache License, Version 2.0 (the "License");
5a196e50eSopenharmony_ci     you may not use this file except in compliance with the License.
6a196e50eSopenharmony_ci     You may obtain a copy of the License at
7a196e50eSopenharmony_ci
8a196e50eSopenharmony_ci          http://www.apache.org/licenses/LICENSE-2.0
9a196e50eSopenharmony_ci
10a196e50eSopenharmony_ci     Unless required by applicable law or agreed to in writing, software
11a196e50eSopenharmony_ci     distributed under the License is distributed on an "AS IS" BASIS,
12a196e50eSopenharmony_ci     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13a196e50eSopenharmony_ci     See the License for the specific language governing permissions and
14a196e50eSopenharmony_ci     limitations under the License.
15a196e50eSopenharmony_ci
16a196e50eSopenharmony_ci     Notes:
17a196e50eSopenharmony_ci     This is project config file for OpenHarmony OSS Audit Tool, if you have any questions or concerns, please email chenyaxun.
18a196e50eSopenharmony_ci-->
19a196e50eSopenharmony_ci<!-- OAT(OSS Audit Tool) configuration guide:
20a196e50eSopenharmony_cibasedir: Root dir, the basedir + project path is the real source file location.
21a196e50eSopenharmony_cilicensefile:
22a196e50eSopenharmony_ci1.If the project don't have "LICENSE" in root dir, please define all the license files in this project in , OAT will check license files according to this rule.
23a196e50eSopenharmony_ci
24a196e50eSopenharmony_citasklist(only for batch mode):
25a196e50eSopenharmony_ci1. task: Define oat check thread, each task will start a new thread.
26a196e50eSopenharmony_ci2. task name: Only an name, no practical effect.
27a196e50eSopenharmony_ci3. task policy: Default policy for projects under this task, this field is required and the specified policy must defined in policylist.
28a196e50eSopenharmony_ci4. task filter: Default filefilter for projects under this task, this field is required and the specified filefilter must defined in filefilterlist.
29a196e50eSopenharmony_ci5. task project: Projects to be checked, the path field define the source root dir of the project.
30a196e50eSopenharmony_ci
31a196e50eSopenharmony_ci
32a196e50eSopenharmony_cipolicyList:
33a196e50eSopenharmony_ci1. policy: All policyitems will be merged to default OAT.xml rules, the name of policy doesn't affect OAT check process.
34a196e50eSopenharmony_ci2. policyitem: The fields type, name, path, desc is required, and the fields rule, group, filefilter is optional,the default value is:
35a196e50eSopenharmony_ci<policyitem type="" name="" path="" desc="" rule="may" group="defaultGroup" filefilter="defaultPolicyFilter"/>
36a196e50eSopenharmony_ci3. policyitem type:
37a196e50eSopenharmony_ci    "compatibility" is used to check license compatibility in the specified path;
38a196e50eSopenharmony_ci    "license" is used to check source license header in the specified path;
39a196e50eSopenharmony_ci    "copyright" is used to check source copyright header in the specified path;
40a196e50eSopenharmony_ci    "import" is used to check source dependency in the specified path, such as import ... ,include ...
41a196e50eSopenharmony_ci    "filetype" is used to check file type in the specified path, supported file types: archive, binary
42a196e50eSopenharmony_ci    "filename" is used to check whether the specified file exists in the specified path(support projectroot in default OAT.xml), supported file names: LICENSE, README, README.OpenSource
43a196e50eSopenharmony_ci
44a196e50eSopenharmony_ci4. policyitem name: This field is used for define the license, copyright, "*" means match all, the "!" prefix means could not match this value. For example, "!GPL" means can not use GPL license.
45a196e50eSopenharmony_ci5. policyitem path: This field is used for define the source file scope to apply this policyitem, the "!" prefix means exclude the files. For example, "!.*/lib/.*" means files in lib dir will be exclude while process this policyitem.
46a196e50eSopenharmony_ci6. policyitem rule and group: These two fields are used together to merge policy results. "may" policyitems in the same group means any one in this group passed, the result will be passed.
47a196e50eSopenharmony_ci7. policyitem filefilter: Used to bind filefilter which define filter rules.
48a196e50eSopenharmony_ci8. filefilter: Filter rules, the type filename is used to filter file name, the type filepath is used to filter file path.
49a196e50eSopenharmony_ci
50a196e50eSopenharmony_ciNote:If the text contains special characters, please escape them according to the following rules:
51a196e50eSopenharmony_ci" == &gt;
52a196e50eSopenharmony_ci& == &gt;
53a196e50eSopenharmony_ci' == &gt;
54a196e50eSopenharmony_ci< == &gt;
55a196e50eSopenharmony_ci> == &gt;
56a196e50eSopenharmony_ci-->
57a196e50eSopenharmony_ci<configuration>
58a196e50eSopenharmony_ci    <oatconfig>
59a196e50eSopenharmony_ci        
60a196e50eSopenharmony_ci        <licensematcherlist>
61a196e50eSopenharmony_ci            <licensematcher name="BSD 2-Clause License" desc="如果工具扫描是InvalidLicense,可在此定义匹配规则,注意引号要转义" >
62a196e50eSopenharmony_ci            <licensetext name="This program is released under the terms of the license contained
63a196e50eSopenharmony_ci   in the file LICENSE." desc="文件为BSD 2-Clause License"/>
64a196e50eSopenharmony_ci            </licensematcher>
65a196e50eSopenharmony_ci        </licensematcherlist>
66a196e50eSopenharmony_ci        <policylist>
67a196e50eSopenharmony_ci            <policy name="projectPolicy" desc="">
68a196e50eSopenharmony_ci                <policyitem type="compatibility" name="bzip2 and libbzip2 License" path="LICENSE" desc="The bzip2 Project LICENSE"/>
69a196e50eSopenharmony_ci            </policy>
70a196e50eSopenharmony_ci        </policylist>
71a196e50eSopenharmony_ci        <filefilterlist>
72a196e50eSopenharmony_ci            <filefilter name="defaultFilter" desc="Files not to check">
73a196e50eSopenharmony_ci                <filteritem type="filename" name="sample*.*" desc="This is sample file, no need license"/>
74a196e50eSopenharmony_ci                <filteritem type="filename" name="dlltest.dsp" desc="This is dll test project file, no need license"/>
75a196e50eSopenharmony_ci                <filteritem type="filename" name="libbz2.dsp" desc="This is project file, no need license"/>
76a196e50eSopenharmony_ci                <filteritem type="filename" name="manual.pdf" desc="This is manual pdf file, no need license"/>
77a196e50eSopenharmony_ci                <filteritem type="filename" name="LICENSE" desc="This is LICENSE file, no need license"/>
78a196e50eSopenharmony_ci                <filteritem type="filename" name="manual.xml" desc="This is manual xml file, no need license"/>
79a196e50eSopenharmony_ci                <filteritem type="filename" name="bzip2.spec" desc="This is project file, no need license"/>
80a196e50eSopenharmony_ci                <filteritem type="filename" name="install.sh" desc="This is project file, no need license"/>
81a196e50eSopenharmony_ci            </filefilter>
82a196e50eSopenharmony_ci        </filefilterlist>
83a196e50eSopenharmony_ci    </oatconfig>
84a196e50eSopenharmony_ci</configuration>
85