1e0dac50fSopenharmony_ci<?xml version="1.0" encoding="UTF-8"?> 2e0dac50fSopenharmony_ci<!-- Copyright (c) 2022 Huawei Device Co., Ltd. 3e0dac50fSopenharmony_ci Licensed under the Apache License, Version 2.0 (the "License"); 4e0dac50fSopenharmony_ci you may not use this file except in compliance with the License. 5e0dac50fSopenharmony_ci You may obtain a copy of the License at 6e0dac50fSopenharmony_ci 7e0dac50fSopenharmony_ci http://www.apache.org/licenses/LICENSE-2.0 8e0dac50fSopenharmony_ci 9e0dac50fSopenharmony_ci Unless required by applicable law or agreed to in writing, software 10e0dac50fSopenharmony_ci distributed under the License is distributed on an "AS IS" BASIS, 11e0dac50fSopenharmony_ci WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12e0dac50fSopenharmony_ci See the License for the specific language governing permissions and 13e0dac50fSopenharmony_ci limitations under the License. 14e0dac50fSopenharmony_ci 15e0dac50fSopenharmony_ci Notes: 16e0dac50fSopenharmony_ci This is project config file for OpenHarmony OSS Audit Tool, if you have any questions or concerns, please email chenyaxun. 17e0dac50fSopenharmony_ci--> 18e0dac50fSopenharmony_ci<!-- OAT(OSS Audit Tool) configuration guide: 19e0dac50fSopenharmony_cibasedir: Root dir, the basedir + project path is the real source file location. 20e0dac50fSopenharmony_cilicensefile: 21e0dac50fSopenharmony_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. 22e0dac50fSopenharmony_ci 23e0dac50fSopenharmony_citasklist(only for batch mode): 24e0dac50fSopenharmony_ci1. task: Define oat check thread, each task will start a new thread. 25e0dac50fSopenharmony_ci2. task name: Only an name, no practical effect. 26e0dac50fSopenharmony_ci3. task policy: Default policy for projects under this task, this field is required and the specified policy must defined in policylist. 27e0dac50fSopenharmony_ci4. task filter: Default filefilter for projects under this task, this field is required and the specified filefilter must defined in filefilterlist. 28e0dac50fSopenharmony_ci5. task project: Projects to be checked, the path field define the source root dir of the project. 29e0dac50fSopenharmony_ci 30e0dac50fSopenharmony_ci 31e0dac50fSopenharmony_cipolicyList: 32e0dac50fSopenharmony_ci1. policy: All policyitems will be merged to default OAT.xml rules, the name of policy doesn't affect OAT check process. 33e0dac50fSopenharmony_ci2. policyitem: The fields type, name, path, desc is required, and the fields rule, group, filefilter is optional,the default value is: 34e0dac50fSopenharmony_ci<policyitem type="" name="" path="" desc="" rule="may" group="defaultGroup" filefilter="defaultPolicyFilter"/> 35e0dac50fSopenharmony_ci3. policyitem type: 36e0dac50fSopenharmony_ci "compatibility" is used to check license compatibility in the specified path; 37e0dac50fSopenharmony_ci "license" is used to check source license header in the specified path; 38e0dac50fSopenharmony_ci "copyright" is used to check source copyright header in the specified path; 39e0dac50fSopenharmony_ci "import" is used to check source dependency in the specified path, such as import ... ,include ... 40e0dac50fSopenharmony_ci "filetype" is used to check file type in the specified path, supported file types: archive, binary 41e0dac50fSopenharmony_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 42e0dac50fSopenharmony_ci 43e0dac50fSopenharmony_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. 44e0dac50fSopenharmony_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. 45e0dac50fSopenharmony_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. 46e0dac50fSopenharmony_ci7. policyitem filefilter: Used to bind filefilter which define filter rules. 47e0dac50fSopenharmony_ci8. filefilter: Filter rules, the type filename is used to filter file name, the type filepath is used to filter file path. 48e0dac50fSopenharmony_ci 49e0dac50fSopenharmony_ciNote:If the text contains special characters, please escape them according to the following rules: 50e0dac50fSopenharmony_ci" == > 51e0dac50fSopenharmony_ci& == > 52e0dac50fSopenharmony_ci' == > 53e0dac50fSopenharmony_ci< == > 54e0dac50fSopenharmony_ci> == > 55e0dac50fSopenharmony_ci--> 56e0dac50fSopenharmony_ci<configuration> 57e0dac50fSopenharmony_ci <oatconfig> 58e0dac50fSopenharmony_ci <licensefile>LICENSE</licensefile> 59e0dac50fSopenharmony_ci <filefilterlist> 60e0dac50fSopenharmony_ci <filefilter name="defaultFilter" desc="Files that do not need to be scanned"> 61e0dac50fSopenharmony_ci <filteritem type="filename" name="*.cfg" desc="cfg no need to add policy"/> 62e0dac50fSopenharmony_ci <filteritem type="filename" name="hvigorfile.js" desc=".js not need check"/> 63e0dac50fSopenharmony_ci </filefilter> 64e0dac50fSopenharmony_ci <filefilter name="binaryFileTypePolicyFilter" desc="Filters for binary file policies" > 65e0dac50fSopenharmony_ci <filteritem type="filepath" name="figures/.*" desc="Self-developed image"/> 66e0dac50fSopenharmony_ci <filteritem type="filepath" name=".*.db" desc="Database data file used for test case execution."/> 67e0dac50fSopenharmony_ci </filefilter> 68e0dac50fSopenharmony_ci </filefilterlist> 69e0dac50fSopenharmony_ci </oatconfig> 70e0dac50fSopenharmony_ci</configuration> 71