license-maven-plugin:在依赖关系报告中包含丢失的许可证

时间:2013-08-21 08:14:29

标签: java maven licensing

我有一个多模块构建,有很多依赖项。每个子项目都有自己的依赖项报告,并且有一个项目依赖于(传递)所有其他项目。现在有许多依赖项缺少许可信息。我想在依赖项报告中包含所有这些丢失的许可证。但我似乎无法让这个工作。有没有人有建议?

我目前正在尝试的是:

  • 在父项目中,我通过添加带有这些名称的子目录,在src / license中定义了各种第三方许可证,如“eula”,“potix_eula”,“bsd_pgsql”,...
  • 在这些目录中,我有许可证的header.txt和license.txt文件
  • 在这个src / license目录中我有一个licenses.properties,其条目如“potix_eula = potix_eula”
  • 在这个src / license目录中,我还有一个带有
  • 等条目的licenses.xml
<dependency>
  <groupId>org.postgresql</groupId>
  <artifactId>jdbc4</artifactId>
  <licenses><license><name>bsd_pgsql</name></license></licenses>
</dependency>
  • 在父项目的pom中,我配置了license-maven-plugin:
<plugin>
  <groupId>org.codehaus.mojo</groupId>
<artifactId>license-maven-plugin</artifactId>
<version>1.5</version>
<configuration>         
      <useMissingFile>true</useMissingFile>
      <licensesConfigFile>C:/eclipse-workspace-kepler/TheParentProject/src/license/licenses.xml</licensesConfigFile>
      <licenseName>zk_potix_eula</licenseName>
      <licenseName>bsd_pgsql</licenseName>
      <licenseResolver>file://${project.basedir}/src/license</licenseResolver>
      <licenseMerges>...</licenseMerges> 
    </configuration>
        <executions>
          <execution>
          <id>first</id>
          <goals>
            <goal>update-file-header</goal>
          </goals>
          <phase>process-sources</phase>
        </execution>
          <execution>
            <id>download-licenses</id>
            <phase>process-resources</phase>
            <goals>
              <goal>download-licenses</goal>
            </goals>
          </execution>
        <execution>
          <id>add-third-party</id>
          <phase>process-resources</phase>
          <goals>
            <goal>aggregate-add-third-party</goal>
          </goals>
        </execution>
      </executions>
     </plugin>
  • 我在所有项目中都生成了THIRD-PARTY.properties并定义了这样的许可证:commons.apache.org - commons-configuration - 1.7 = apache_v2
  • 我还尝试将src / license目录从父目录复制到模块的所有src目录中。它仍然无效。

1 个答案:

答案 0 :(得分:1)

我知道,我忘记了包含所有必要信息的第三方报告。

  <plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>license-maven-plugin</artifactId>
    <version>1.5</version>
    <configuration>
      <useMissingFile>true</useMissingFile>
      <useRepositoryMissingFiles>true</useRepositoryMissingFiles>
        <licenseName>zk_potix_eula</licenseName>
        <licenseName>bsd_pgsql</licenseName>
        <licenseName>bsd_hamcrest</licenseName>
        <licenseName>bsd_dom4j</licenseName>
        <licenseResolver>file://${project.parent.basedir}/src/license</licenseResolver>
        <licenseMerges>
          <licenseMerge>Apache 2.0|The Apache Software License, Version 2.0|Apache License, Version 2.0|apache_v2</licenseMerge>
          <licenseMerge>CDDL 1.0|COMMON DEVELOPMENT AND DISTRIBUTION LICENSE (CDDL) Version 1.0|Common Development and Distribution License (CDDL) v1.0|cddl_v1</licenseMerge>
          <licenseMerge>GNU LGPL 2.1|GNU Lesser General Public License (LGPL), Version 2.1|GNU Lesser General Public License, version 2.1|lgpl_v2_1</licenseMerge>
          <licenseMerge>GNU LGPL 3|GNU LESSER GENERAL PUBLIC LICENSE, Version 3|GNU Lesser General Public Licence|GNU Lesser General Public License|GNU LESSER GENERAL PUBLIC LICENSE</licenseMerge>
          <licenseMerge>Dual license: CDDL 1.0 and GPL v2|Dual license consisting of the CDDL v1.0 and GPL v2|CDDL+GPLv2|CDDL+GPL|CDDL+GPL License</licenseMerge>
          <licenseMerge>Dual license: CDDL 1.1 and GPL v2|Dual license consisting of the CDDL v1.1 and GPL v2|CDDL1_1+GPLv2</licenseMerge>
          <licenseMerge>Dual License: CDDL 1.0 and GPL V2 with Classpath Exception|CDDL + GPLv2 with classpath exception</licenseMerge>
        </licenseMerges> 
    </configuration>
  </plugin>