122736c2fSopenharmony_ci<?xml version="1.0" encoding="UTF-8"?>
222736c2fSopenharmony_ci<!-- Copyright (c) 2024 Huawei Device Co., Ltd.
322736c2fSopenharmony_ci
422736c2fSopenharmony_ci     Licensed under the Apache License, Version 2.0 (the "License");
522736c2fSopenharmony_ci     you may not use this file except in compliance with the License.
622736c2fSopenharmony_ci     You may obtain a copy of the License at
722736c2fSopenharmony_ci
822736c2fSopenharmony_ci          http://www.apache.org/licenses/LICENSE-2.0
922736c2fSopenharmony_ci
1022736c2fSopenharmony_ci     Unless required by applicable law or agreed to in writing, software
1122736c2fSopenharmony_ci     distributed under the License is distributed on an "AS IS" BASIS,
1222736c2fSopenharmony_ci     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1322736c2fSopenharmony_ci     See the License for the specific language governing permissions and
1422736c2fSopenharmony_ci     limitations under the License.
1522736c2fSopenharmony_ci
1622736c2fSopenharmony_ci-->
1722736c2fSopenharmony_ci<!-- OAT(OSS Audit Tool) configuration guide:
1822736c2fSopenharmony_cibasedir: Root dir, the basedir + project path is the real source file location.
1922736c2fSopenharmony_cilicensefile:
2022736c2fSopenharmony_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.
2122736c2fSopenharmony_ci
2222736c2fSopenharmony_citasklist(only for batch mode):
2322736c2fSopenharmony_ci1. task: Define oat check thread, each task will start a new thread.
2422736c2fSopenharmony_ci2. task name: Only an name, no practical effect.
2522736c2fSopenharmony_ci3. task policy: Default policy for projects under this task, this field is required and the specified policy must defined in policylist.
2622736c2fSopenharmony_ci4. task filter: Default filefilter for projects under this task, this field is required and the specified filefilter must defined in filefilterlist.
2722736c2fSopenharmony_ci5. task project: Projects to be checked, the path field define the source root dir of the project.
2822736c2fSopenharmony_ci
2922736c2fSopenharmony_ci
3022736c2fSopenharmony_cipolicyList:
3122736c2fSopenharmony_ci1. policy: All policyitems will be merged to default OAT.xml rules, the name of policy doesn't affect OAT check process.
3222736c2fSopenharmony_ci2. policyitem: The fields type, name, path, desc is required, and the fields rule, group, filefilter is optional,the default value is:
3322736c2fSopenharmony_ci<policyitem type="" name="" path="" desc="" rule="may" group="defaultGroup" filefilter="defaultPolicyFilter"/>
3422736c2fSopenharmony_ci3. policyitem type:
3522736c2fSopenharmony_ci    "compatibility" is used to check license compatibility in the specified path;
3622736c2fSopenharmony_ci    "license" is used to check source license header in the specified path;
3722736c2fSopenharmony_ci    "copyright" is used to check source copyright header in the specified path;
3822736c2fSopenharmony_ci    "import" is used to check source dependency in the specified path, such as import ... ,include ...
3922736c2fSopenharmony_ci    "filetype" is used to check file type in the specified path, supported file types: archive, binary
4022736c2fSopenharmony_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
4122736c2fSopenharmony_ci
4222736c2fSopenharmony_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.
4322736c2fSopenharmony_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.
4422736c2fSopenharmony_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.
4522736c2fSopenharmony_ci7. policyitem filefilter: Used to bind filefilter which define filter rules.
4622736c2fSopenharmony_ci8. filefilter: Filter rules, the type filename is used to filter file name, the type filepath is used to filter file path.
4722736c2fSopenharmony_ci
4822736c2fSopenharmony_ciNote:If the text contains special characters, please escape them according to the following rules:
4922736c2fSopenharmony_ci" == &gt;
5022736c2fSopenharmony_ci& == &gt;
5122736c2fSopenharmony_ci' == &gt;
5222736c2fSopenharmony_ci< == &gt;
5322736c2fSopenharmony_ci> == &gt;
5422736c2fSopenharmony_ci-->
5522736c2fSopenharmony_ci<configuration>
5622736c2fSopenharmony_ci    <oatconfig>
5722736c2fSopenharmony_ci        <licensefile>LICENSE</licensefile>
5822736c2fSopenharmony_ci        <filefilterlist>
5922736c2fSopenharmony_ci            <filefilter name="defaultFilter" desc="Files that do not need to be scanned">
6022736c2fSopenharmony_ci                <filteritem type="filename" name="*.cfg" desc="cfg no need to add policy"/>
6122736c2fSopenharmony_ci            </filefilter>
6222736c2fSopenharmony_ci            <filefilter name="binaryFileTypePolicyFilter" desc="Filters for binary file policies">
6322736c2fSopenharmony_ci                <filteritem type="filename" name="*.png" desc="png for hap"/>
6422736c2fSopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/bundle_dependencies/editorBox/entry/src/main/resources/base/media/icon.png"
6522736c2fSopenharmony_ci							desc="png for unittest"/>
6622736c2fSopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/bundle_dependencies/extImfBundle/entry/src/main/resources/base/media/icon.png"
6722736c2fSopenharmony_ci							desc="png for unittest"/>
6822736c2fSopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/bundle_dependencies/newTestIme/entry/src/main/resources/base/media/icon.png"
6922736c2fSopenharmony_ci							desc="png for unittest"/>
7022736c2fSopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/bundle_dependencies/extImfBundle/AppScope/resources/base/media/app_icon.png"
7122736c2fSopenharmony_ci							desc="png for unittest"/>
7222736c2fSopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/bundle_dependencies/editorBox/AppScope/resources/base/media/app_icon.png"
7322736c2fSopenharmony_ci							desc="png for unittest"/>
7422736c2fSopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/bundle_dependencies/newTestIme/AppScope/resources/base/media/app_icon.png"
7522736c2fSopenharmony_ci							desc="png for unittest"/>
7622736c2fSopenharmony_ci                <filteritem type="filepath" name="services/dialog/entry/src/main/resources/base/media/icon.png"
7722736c2fSopenharmony_ci							desc="png for hap"/>
7822736c2fSopenharmony_ci                <filteritem type="filepath" name="services/dialog/AppScope/resources/base/media/app_icon.png"
7922736c2fSopenharmony_ci							desc="png for hap"/>
8022736c2fSopenharmony_ci                <filteritem type="filepath" name="figures/subsystem_architecture_zh.png"
8122736c2fSopenharmony_ci							desc="png for readme_zh"/>
8222736c2fSopenharmony_ci                <filteritem type="filepath" name="figures/subsystem_architecture.png"
8322736c2fSopenharmony_ci							desc="png for readme"/>
8422736c2fSopenharmony_ci            </filefilter>
8522736c2fSopenharmony_ci        </filefilterlist>
8622736c2fSopenharmony_ci    </oatconfig>
8722736c2fSopenharmony_ci</configuration>