forked from eclipse-archived/antenna
-
Notifications
You must be signed in to change notification settings - Fork 2
/
index.md.vm
99 lines (65 loc) · 4.27 KB
/
index.md.vm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# About
[${docNameCap}](https://www.eclipse.org/antenna/) scans artifacts of a project, downloads sources for dependencies,
validates sources and licenses and creates:
* a third-party attribution document that lists all dependencies with
their licenses
* an artifact information *.csv-file containing a list of the artifacts coordinate and license data
* a sources.zip containing all sources of the dependencies
* a processing report.
Additionally, ${docNameCap} provides information and warnings about [security issues](./processors/security-issue-validator.html).
![Process of ${docNameCap}](../images/antenna-process.png)
#[[##]]# Explanation of process
#[[###]]# <span style="color:#73ffdb">Phase 1 - Analyzers</span>
This phase is done by the [Maven Dependency Tree Analyzer](analyzers/mvn-dep-tree-analyzer-step.html) or/and an external tool. The tool scans your project and determines which dependencies
and licenses are being used by it. Usually this results is a scan report which contains the findings. ${docNameCap} is able to trigger this phase for you
[(see Workflow Configuration)](workflow-configuration.html).
It is possible to add additional analyzers to the [Maven Dependency Tree Analyzer](analyzers/mvn-dep-tree-analyzer-step.html) to find more artifacts.
This could be necessary, for example, if you use a language that is not supported by Maven or have another dependency analyzer you trust more.
Those can be implemented externally and added to the workflow.
#[[###]]# <span style="color:#73a9ff">Phase 2 - Processors</span>
#[[####]]# Download of sources and artifacts
In this phase ${docNameCap} downloads the source codes and licences of the artifacts, which are defined in the report of phase 1.
Both, the source code and the licence have to be validated.
#[[#####]]# Validation:
**Source validation**: The source jar is compared to the jar file,
if it exists. If no jar exists, a NO_JAR message is added to the
processing report and the sources jar is handled as valid.
**License validation**: It is checked whether a license has a license
text and if the artifacts list contains forbidden licenses.
It is possible to add more steps here that validate the sources for different criteria or enrich the source information.
#[[###]]# <span style="color:#ff7873">Phase 3 - Generators</span>
In the last phase ${docNameCap} generates the attribution document and bundles all existing sources into a zip file.
#[[####]]# Creation of attribution document:
All information from the artifacts list is added to the attribution
document. The document contains a list of artifacts with filename,
maven coordinates and licenses.
The full license text is appended for each license.
#[[####]]# Creation of sources zip
All existing sources, that do not have Match State *UNKNOWN* or *SIMILAR*,
are added to the zip. The Match State can be overridden in the
configuration file.
When using ${docNameCap} as a Maven plugin, sources will be obtained from Maven.
However, when using ${docNameCap} as a CLI an alternative
method is available for downloading jar files that functions without
having Maven installed. To use it, set these properties in your
project's pom.xml file as described in
[How to configure ${docNameCap}](tool-configuration.html#Explanation_of_parameters).
It is possible to add additional steps here that generate additional documents you might want or need.
#[[###]]# Attach artifacts
It is possible to attach artifacts created by ${docNameCap} directly to the
build job. For more information read
[How to configure ${docNameCap}](tool-configuration.html#Explanation_of_parameters).
#[[###]]# Attach workflow steps
It is possible to add additional steps to the phases.
There you can, for example, add an additional analyzer (like a JSON Analyzer),
processor step (like a rule engine or a security issue validator)
or generator step (like a HTML report generator).
#[[##]]# How ${docNameCap} resolves the license
#[[###]]# Resolution priority
${docNameCap} will choose among all reported licenses the license with the
highest priority:
1. Configured license
2. Overwritten license
3. Declared license
However, there is a possibility to set a `finalLicense` for an artifact in the ${docNameCap} Configuration.
Consequently, that set `finalLicense` then has priority above all other found licenses.