1ce968135Sopenharmony_ci<?xml version="1.0" encoding="UTF-8"?>
2ce968135Sopenharmony_ci<!-- Copyright (c) 2021 Huawei Device Co., Ltd.
3ce968135Sopenharmony_ci
4ce968135Sopenharmony_ci     Licensed under the Apache License, Version 2.0 (the "License");
5ce968135Sopenharmony_ci     you may not use this file except in compliance with the License.
6ce968135Sopenharmony_ci     You may obtain a copy of the License at
7ce968135Sopenharmony_ci
8ce968135Sopenharmony_ci          http://www.apache.org/licenses/LICENSE-2.0
9ce968135Sopenharmony_ci
10ce968135Sopenharmony_ci     Unless required by applicable law or agreed to in writing, software
11ce968135Sopenharmony_ci     distributed under the License is distributed on an "AS IS" BASIS,
12ce968135Sopenharmony_ci     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13ce968135Sopenharmony_ci     See the License for the specific language governing permissions and
14ce968135Sopenharmony_ci     limitations under the License.
15ce968135Sopenharmony_ci
16ce968135Sopenharmony_ci-->
17ce968135Sopenharmony_ci<!-- OAT(OSS Audit Tool) configuration guide:
18ce968135Sopenharmony_cibasedir: Root dir, the basedir + project path is the real source file location.
19ce968135Sopenharmony_cilicensefile:
20ce968135Sopenharmony_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.
21ce968135Sopenharmony_ci
22ce968135Sopenharmony_citasklist(only for batch mode):
23ce968135Sopenharmony_ci1. task: Define oat check thread, each task will start a new thread.
24ce968135Sopenharmony_ci2. task name: Only an name, no practical effect.
25ce968135Sopenharmony_ci3. task policy: Default policy for projects under this task, this field is required and the specified policy must defined in policylist.
26ce968135Sopenharmony_ci4. task filter: Default filefilter for projects under this task, this field is required and the specified filefilter must defined in filefilterlist.
27ce968135Sopenharmony_ci5. task project: Projects to be checked, the path field define the source root dir of the project.
28ce968135Sopenharmony_ci
29ce968135Sopenharmony_ci
30ce968135Sopenharmony_cipolicyList:
31ce968135Sopenharmony_ci1. policy: All policyitems will be merged to default OAT.xml rules, the name of policy doesn't affect OAT check process.
32ce968135Sopenharmony_ci2. policyitem: The fields type, name, path, desc is required, and the fields rule, group, filefilter is optional,the default value is:
33ce968135Sopenharmony_ci<policyitem type="" name="" path="" desc="" rule="may" group="defaultGroup" filefilter="defaultPolicyFilter"/>
34ce968135Sopenharmony_ci3. policyitem type:
35ce968135Sopenharmony_ci    "compatibility" is used to check license compatibility in the specified path;
36ce968135Sopenharmony_ci    "license" is used to check source license header in the specified path;
37ce968135Sopenharmony_ci    "copyright" is used to check source copyright header in the specified path;
38ce968135Sopenharmony_ci    "import" is used to check source dependency in the specified path, such as import ... ,include ...
39ce968135Sopenharmony_ci    "filetype" is used to check file type in the specified path, supported file types: archive, binary
40ce968135Sopenharmony_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
41ce968135Sopenharmony_ci
42ce968135Sopenharmony_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.
43ce968135Sopenharmony_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.
44ce968135Sopenharmony_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.
45ce968135Sopenharmony_ci7. policyitem filefilter: Used to bind filefilter which define filter rules.
46ce968135Sopenharmony_ci8. filefilter: Filter rules, the type filename is used to filter file name, the type filepath is used to filter file path.
47ce968135Sopenharmony_ci
48ce968135Sopenharmony_ciNote:If the text contains special characters, please escape them according to the following rules:
49ce968135Sopenharmony_ci" == &gt;
50ce968135Sopenharmony_ci& == &gt;
51ce968135Sopenharmony_ci' == &gt;
52ce968135Sopenharmony_ci< == &gt;
53ce968135Sopenharmony_ci> == &gt;
54ce968135Sopenharmony_ci-->
55ce968135Sopenharmony_ci<configuration>
56ce968135Sopenharmony_ci    <oatconfig>
57ce968135Sopenharmony_ci        <licensefile>LICENSE</licensefile>
58ce968135Sopenharmony_ci        <filefilterlist>
59ce968135Sopenharmony_ci            <filefilter name="defaultFilter" desc="Files that do not need to be scanned">
60ce968135Sopenharmony_ci                <filteritem type="filename" name="*.cfg" desc="cfg no need to add policy"/>
61ce968135Sopenharmony_ci            </filefilter>
62ce968135Sopenharmony_ci            <filefilter name="binaryFileTypePolicyFilter" desc="Filters for binary file policies">
63ce968135Sopenharmony_ci                <filteritem type="filename" name="*.png" desc="png for hap"/>
64ce968135Sopenharmony_ci                <filteritem type="filepath" name="frameworks/js/napi/test/unittest/resource/wallpaper_lock.JPG"
65ce968135Sopenharmony_ci                            desc="JPG for js tdd test"/>
66ce968135Sopenharmony_ci                <filteritem type="filepath" name="frameworks/js/napi/test/unittest/resource/wallpaper_system.JPG"
67ce968135Sopenharmony_ci                            desc="JPG for js tdd test"/>
68ce968135Sopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/wallpaper_test.JPG" desc="JPG for unittest"/>
69ce968135Sopenharmony_ci                <filteritem type="filename" name="*.mp4" desc="mp4 need to add policy"/>
70ce968135Sopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/15fps_4s.mp4" 
71ce968135Sopenharmony_ci                            desc="mp4 for unittest"/>
72ce968135Sopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/30fps_6s.mp4" 
73ce968135Sopenharmony_ci                            desc="mp4 for unittest"/>
74ce968135Sopenharmony_ci                <filteritem type="filename" name="*.mov" desc="mov not need to add policy"/>
75ce968135Sopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/30fps_4s.mov" 
76ce968135Sopenharmony_ci                            desc="mov for unittest"/>
77ce968135Sopenharmony_ci                <filteritem type="filename" name="*.zip" desc="zip need to add policy"/>
78ce968135Sopenharmony_ci                <filteritem type="filepath" name="test/unittest/resource/test.zip" 
79ce968135Sopenharmony_ci                            desc="zip for unittest"/>
80ce968135Sopenharmony_ci                <filteritem type="filename" name="*.jpeg" desc="jpeg need to add policy"/>
81ce968135Sopenharmony_ci                <filteritem type="filepath" name="frameworks/native/data/wallpaperdefault.jpeg" 
82ce968135Sopenharmony_ci                            desc="jpeg for prebuild"/>
83ce968135Sopenharmony_ci                <filteritem type="filepath" name="frameworks/native/data/wallpaperlockdefault.jpeg" 
84ce968135Sopenharmony_ci                            desc="jpeg for prebuild"/>
85ce968135Sopenharmony_ci            </filefilter>
86ce968135Sopenharmony_ci        </filefilterlist>
87ce968135Sopenharmony_ci    </oatconfig>
88ce968135Sopenharmony_ci</configuration>