One instance of the Package Information is required per package being described. A package can contain sub-packages, but the information in this section is a reference to the entire contents of the package listed. Starting with SPDX 2.0, it is not necessary to have a package wrapping a set of files.
Cardinality: Optional, one or many.
In tag:value format, the order in which package and files occur is syntactically significant.
A new Package Information section is denoted by the Package Name field. All Package Information fields must be grouped together before the start of a Files section, if file(s) are present. All files contained in a package must immediately follow the applicable Package Information. A new Package Information section (via Package Name) denotes the start of another package. Sub-packages should not be nested inside a Package Information section, but should be separate and should use a Relationship to clarify. Annotations and Relationships for the package may appear after the Package Information before any file information.
Fields:
3.1.1 Purpose: Identify the full name of the package as given by Package Originator.
3.1.2 Intent: Here, the name of each package is an important conventional technical identifier to be maintained for each package.
3.1.3 Cardinality: Mandatory, one.
3.1.4 DataFormat: single line of text.
3.1.5 Tag: PackageName:
Example:
PackageName: glibc
3.1.6 RDF: property spdx:name
in class spdx:Package
Example:
<Package rdf:about="...">
<name>glibc</name>
</Package>
3.2.1 Purpose: Uniquely identify any element in an SPDX document which may be referenced by other elements. These may be referenced internally and externally with the addition of the SPDX Document Identifier.
3.2.2 Intent: There may be several versions of the same package within an SPDX document. Each element needs to be able to be referred to uniquely so that relationships between elements can be clearly articulated.
3.2.3 Cardinality: Mandatory, one.
3.2.4 DataFormat: “SPDXRef-[idstring]
where [idstring] is a unique string containing letters, numbers, “.”,“-”.
3.2.5 Tag: SPDXID:
Example:
SPDXID: SPDXRef-1
3.2.6 RDF: The URI for the element will follow the form:
[SPDX DocumentNamespace]#[SPDX Identifier]
See section 2.5 for the definition of the SPDX Document Namespace and section 2.3 for the definition of the SPDX Identifier
Example using xml:base:
<rdf:RDF xml:base="http://acme.com/spdxdocs/acmeproj/v1.2/1BE2A4FF-5F1A-48D3-8483-28A9B0349A1B">
...
<Package rdf:ID=”SPDXRef-1”>
...
</Package>
Example using document URI:
<Package rdf:about="http://acme.com/spdxdocs/acmeproj/v1.2/1BE2A4FF-5F1A-48D3-8483-28A9B0349...">
...
</Package>
3.3.1 Purpose: Identify the version of the package.
3.3.2 Intent: The versioning of a package is a useful for identification purposes and for indicating later changes of the package version.
3.3.3 Cardinality: Optional, one.
3.3.4 DataFormat: single line of text.
3.3.5 Tag: PackageVersion:
Example:
PackageVersion: 2.11.1
3.3.6 RDF: property spdx:versionInfo
in class spdx:Package
Example:
<Package rdf:about="...">
...
<versionInfo>2.11.1</versionInfo>
...
</Package>
3.4.1 Purpose: Provide the actual file name of the package, or path of the directory being treated as a package. This may include the packaging and compression methods used as part of the file name, if appropriate.
3.4.2 Intent: Here, the actual file name of the compressed file containing the package may be a significant technical element that needs to be included with each package identification information. If a grouping, like a set of files in a subdirectory, is being treated as a package, the subdirectory name may be appropriate to provide. Subdirectory name is preceeded with a “./”, see http://www.ietf.org/rfc/rfc3986.txt for syntax.
3.4.3 Cardinality: Optional, one.
3.4.4 Data Format: single line of text.
3.4.5 Tag: PackageFileName:
Example:
PackageFileName: glibc-2.11.1.tar.gz
Example (subdirectory being treated as a package):
PackageFileName: ./myrootdir/mysubdir1
3.4.6 RDF: property spdx:packageFileName
in class spdx:Package
Example:
<Package rdf:about="...">
...
<packageFileName>glibc 2.11.1.tar.gz</packageFileName>
...
</Package>
Example (subdirectory being treated as a package):
<Package rdf:about="...">
...
<packageFileName>./myrootdir/mysubdir1</packageFileName>
...
</Package>
3.5.1 Purpose: Identify the actual distribution source for the package/directory identified in the SPDX file. This may or may not be different from the originating distribution source for the package. The name of the Package Supplier must be an organization or recognized author and not a web site. For example, Sourceforge is a host website, not a supplier, the supplier for http://sourceforge.net/projects/bridge/ is "The Linux Foundation."
Use NOASSERTION if: (i) the SPDX file creator has attempted to but cannot reach a reasonable objective determination; (ii) the SPDX file creator has made no attempt to determine this field; or (iii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
3.5.2 Intent: This field assists with understanding the point of distribution for the code in the package. This field is vital for ensuring that downstream package recipients can address any ambiguity or concerns that might arise with the information in the SPDX file or the contents of the package it documents.
3.5.3 Cardinality: Optional, one.
3.5.4 Data Format: single line of text with the following keywords | “NOASSERTION”
"Person:" person name and optional "("email")"
"Organization:" organization name and optional "("email")"
3.5.5 Tag: PackageSupplier:
Example:
PackageSupplier: Person: Jane Doe ([email protected])
3.5.6 RDF: property spdx:supplier
in class spdx:Package
Example:
<Package rdf:about="...">
...
<supplier>Person: Jane Doe ([email protected]) </supplier>
...
</Package>
3.6.1 Purpose: If the package identified in the SPDX file originated from a different person or organization than identified as Package Supplier (see section 3.5 above), this field identifies from where or whom the package originally came. In some cases a package may be created and originally distributed by a different third party than the Package Supplier of the package. For example, the SPDX file identifies the package glibc and Red Hat as the Package Supplier, but Free Software Foundation is the Package Originator.
Use NOASSERTION if: (i) the SPDX file creator has attempted to but cannot reach a reasonable objective determination; (ii) the SPDX file creator has made no attempt to determine this field; or (iii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
3.6.2 Intent: This field assists with understanding the point of origin of the code in the package. This field is vital for understanding who originally distributed a package and should help in addressing any ambiguity or concerns that might arise with the information in the SPDX file or the contents of the Package it documents.
3.6.3 Cardinality: Optional, one.
3.6.4 Data Format: single line of text with the following keywords | “NOASSERTION”
"Person:" person name and optional "("email")"
"Organization:" organization name and optional "("email")"
3.6.5 Tag: PackageOriginator:
Example:
PackageOriginator: Organization: ExampleCodeInspect ([email protected])
3.6.6 RDF: property spdx:originator
in class spdx:Package
Example:
<Package rdf:about="...”>
<originator>Organization: ExampleCodeInspect ([email protected])</originator>
</Package>
3.7.1 Purpose: This section identifies the download Universal Resource Locator (URL), or a specific location within a version control system (VCS) for the package at the time that the SPDX file was created.
Use NONE if there is no download location whatsoever.
Use NOASSERTION if: (i) the SPDX file creator has attempted to but cannot reach a reasonable objective determination; (ii) the SPDX file creator has made no attempt to determine this field; or (iii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
3.7.2 Intent: Here, where and how to download the exact package being referenced is critical verification and tracking data.
3.7.3 Cardinality: Mandatory, one.
3.7.4 Data Format: uniform resource locator | VCS location | “NONE” | “NOASSERTION”
For version-controlled files, the VCS location syntax is similar to a URL and has the:
<vcs_tool>+<transport>://<host_name>[/<path_to_repository>][@<revision_tag_or_branch>][#<sub_path>]
This VCS location compact notation (inspired and mostly adopted from https://pip.pypa.io/en/latest/reference/pip_install.html#vcs-support as of 20150220) supports referencing locations in version control systems such as Git, Mercurial, Subversion and Bazaar, and specifies the type of VCS tool using url prefixes: “git+”, “hg+”, “bzr+”, “svn+” and specific transport schemes such as SSH or HTTPS.
Specifying sub-paths, branch names, a commit hash, a revision or a tag name is recommended, and supported using the "@"delimiter for commits and the "#" delimiter for sub-paths.
Using user names and password in the host_name is not supported and should be considered as an error. User access control to URLs or VCS repositories must be handled outside of an SPDX document.
In VCS location compact notations, the trailing slashes in <host_name>
, <path_to_repository>
are not significant. Leading and trailing slashes in <sub_path>
are not significant.
3.7.5 Tag: PackageDownloadLocation:
Examples if ambiguous:
PackageDownloadLocation: NOASSERTION
PackageDownloadLocation: NONE
Example for a plain URL:
PackageDownloadLocation: http://ftp.gnu.org/gnu/glibc/glibc-ports-2.15.tar.gz
Example for Git:
SPDX supports git, git+git, git+https git+http and git+ssh transports. git and git+git are equivalent.
Here are the supported forms:
PackageDownloadLocation: git://git.myproject.org/MyProject
PackageDownloadLocation: git+https://git.myproject.org/MyProject.git
PackageDownloadLocation: git+http://git.myproject.org/MyProject
PackageDownloadLocation: git+ssh://git.myproject.org/MyProject.git
PackageDownloadLocation: git+git://git.myproject.org/MyProject
PackageDownloadLocation: [email protected]:MyProject
To specify a sub-path to a file or directory inside a repository use the "#" delimiter:
PackageDownloadLocation: git://git.myproject.org/MyProject#src/somefile.c
PackageDownloadLocation: git+https://git.myproject.org/MyProject#src/Class.java
To specify branch names, a commit hash or a tag name, use the "@" delimiter:
PackageDownloadLocation: git://git.myproject.org/MyProject.git@master
PackageDownloadLocation: git+https://git.myproject.org/[email protected]
PackageDownloadLocation: git://git.myproject.org/MyProject.git@da39a3ee5e6b4b0d3255bfef95601890afd80709
Sub-paths and branch names or commit hash can be combined too:
PackageDownloadLocation: git+https://git.myproject.org/MyProject.git@master#/src/MyClass.cpp
PackageDownloadLocation: git+https://git.myproject.org/MyProject@da39a3ee5e6b4b0d3255bfef95601890afd80709#lib/variable.rb
Example for Mercurial:
SPDX supported schemes are: hg+http, hg+https, hg+static-http and hg+ssh.
The supported forms are:
PackageDownloadLocation: hg+http://hg.myproject.org/MyProject
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject
PackageDownloadLocation: hg+ssh://hg.myproject.org/MyProject
To specify a sub-path to a file or directory inside a repository use the "#" delimiter:
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject#src/somefile.c
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject#src/Class.java
To pass branch names, a commit hash, a tag name or a local branch name use the "@" delimiter:
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject@da39a3ee5e6b
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject@2019
PackageDownloadLocation: hg+https://hg.myproject.org/[email protected]
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject@special_feature
Sub-paths and branch names or commit hash can be combined too:
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject@master#/src/MyClass.cpp
PackageDownloadLocation: hg+https://hg.myproject.org/MyProject@da39a3ee5e6b#lib/variable.rb
Example for Subversion:
SPDX supports the URL schemes svn, svn+svn, svn+http, svn+https, svn+ssh. svn and svn+svn are equivalent.
The supported forms are:
PackageDownloadLocation: svn://svn.myproject.org/svn/MyProject
PackageDownloadLocation: svn+svn://svn.myproject.org/svn/MyProject
PackageDownloadLocation: svn+http://svn.myproject.org/svn/MyProject/trunk
PackageDownloadLocation: svn+https://svn.myproject.org/svn/MyProject/trunk
To specify a sub-path to a file or directory inside a repository use the "#" delimiter:
PackageDownloadLocation: svn+https://svn.myproject.org/MyProject#src/somefile.c
PackageDownloadLocation: svn+https://svn.myproject.org/MyProject#src/Class.java
This support is less important for SVN since the URL path can also contain sub-paths; this two forms are equivalent:
PackageDownloadLocation: svn+https://svn.myproject.org/MyProject/trunk#src/somefile.c
PackageDownloadLocation: svn+https://svn.myproject.org/MyProject/trunk/src/somefile.c
You can specify a revision using the "@" delimiter:
PackageDownloadLocation: svn+https://svn.myproject.org/svn/MyProject/trunk@2019
Sub-paths and revisions can be combined too:
PackageDownloadLocation: svn+https://svn.myproject.org/MyProject@123#/src/MyClass.cpp
PackageDownloadLocation: svn+https://svn.myproject.org/MyProject/trunk@1234#lib/variable/variable.rb
Example for Bazaar:
SPDX supports Bazaar using the bzr+http, bzr+https, bzr+ssh, bzr+sftp, bzr+ftp and bzr+lp schemes.
The supported forms are:
PackageDownloadLocation: bzr+https://bzr.myproject.org/MyProject/trunk
PackageDownloadLocation: bzr+http://bzr.myproject.org/MyProject/trunk
PackageDownloadLocation: bzr+sftp://myproject.org/MyProject/trunk
PackageDownloadLocation: bzr+ssh://myproject.org/MyProject/trunk
PackageDownloadLocation: bzr+ftp://myproject.org/MyProject/trunk
PackageDownloadLocation: bzr+lp:MyProject
To specify a sub-path to a file or directory inside a repository use the "#" delimiter:
PackageDownloadLocation: bzr+https://bzr.myproject.org/MyProject/trunk#src/somefile.c
PackageDownloadLocation: bzr+https://bzr.myproject.org/MyProject/trunk#src/Class.java
You can specify a revision or tag using the "@" delimiter:
PackageDownloadLocation: bzr+https://bzr.myproject.org/MyProject/trunk@2019
PackageDownloadLocation: bzr+http://bzr.myproject.org/MyProject/[email protected]
Sub-paths and revisions can be combined too:
PackageDownloadLocation: bzr+https://bzr.myproject.org/MyProject/trunk@2019#src/somefile.c
3.7.6 RDF: property spdx:downloadLocation
in class spdx:Package
Example:
<Package rdf:about="...">
<downloadLocation>http://ftp.gnu.org/gnu/glibc/glibc-ports-2.15.tar.gz</downloadLocation>
</Package>
<Package rdf:about="...">
<downloadLocation>
git+https://git.myproject.org/[email protected]#src/lib.c
</downloadLocation>
</Package>
<Package rdf:about="...">
<downloadLocation rdf:resource="http://spdx.org/rdf/terms#noassertion"/>
</Package>
<Package rdf:about="...">
<downloadLocation rdf:resource="http://spdx.org/rdf/terms#none"/>
</Package>
3.8.1 Purpose: Indicates whether the file content of this package has been available for or subjected to analysis when creating the SPDX document. If “false” indicates packages that represent metadata or URI references to a project, product, artifact, distribution or a component. If set to “false”, the package must not contain any files.
3.8.2 Intent: A package can refer to a project, product, artifact, distribution or a component that is external to the SPDX document.
Some examples:
A bundle of external products: Package A can be metadata about Packages and their dependencies. It may also be a loosely organized manifest of references to Packages involved in a product or project. Build or execution may transitively discover more Packages and dependencies. All of these referenced Packages can have their own SPDX Documents. In this case, Package A may be defined with its File Analyzed attribute set to “false”. Package A includes External Document References to SPDX documents containing Packages referenced in all the available relationships. The Relationships section then relates the SPDX documents and contained SPDX elements with appropriate semantics per the dependencies in the scope of Package A. Package relation to external product: Package A can have a STATIC_LINK relationship to Package B, but the binary representation of Package B is furnished by the build process and thus not contained in the file list of Package A. In this case, Package B needs to be defined with its Files Analyzed attribute set to false and all the other attributes subject to the subsequently defined constraints. Then, the relationship between Package A and Package B can be documented as described in Section 7. File derived from external product: Package A contains multiple files derived from an outside project. Rather than use the artifactOf* attributes (Sections 4.9-4.11) to describe the relation of these files to their project, the outside project can be represented by another package, Package B, whose FilesAnalyzed attribute is set to “false”. Each of the binary files can then have a relationship to package B (Section 6). This allows the outside project to be represented by a single SPDX identifier (the identifier of Package B). It also allows the relationship(s) between the outside project and each of the files be represented in much more detail.
3.8.3 Cardinality: Optional, one. (If omitted, the default value of “true” is assumed).
3.8.4 Data Format: Boolean
3.8.5 Tag: FilesAnalyzed
Example:
FilesAnalyzed: false
3.8.6 RDF: property spdx:filesAnalyzed
in class spdx:Package
.
Example:
<Package rdf:about=”...”>
...
<filesAnalyzed>false</filesAnalyzed>
...
</Package>
3.9.1 Purpose: This field provides an independently reproducible mechanism identifying specific contents of a package based on the actual files (except the SPDX file itself, if it is included in the package) that make up each package and that correlates to the data in this SPDX file. This identifier enables a recipient to determine if any file in the original package (that the analysis was done on) has been changed and permits inclusion of an SPDX file as part of a package.
3.9.2 Intent: Providing a unique identifier based on the files inside each package, eliminates confusion over which version or modification of a specific package the SPDX file refers to. It also permits one to embed the SPDX file within the package without altering the identifier.
3.9.3 Cardinality: Mandatory, one if filesAnalyzed is true or omitted, Zero (must be omitted) if filesAnalyzed is false.
3.9.4 Algorithm:
verificationcode = 0
filelist = templist = “”
for all files in the package {
if file is an “excludes” file, skip it /* exclude SPDX analysis file(s) */
append templist with “SHA1(file)/n”
}
sort templist in ascending order by SHA1 value
filelist = templist with "/n"s removed. /* ordered sequence of SHA1 values with no separators */
verificationcode = SHA1(filelist)
Where SHA1(file) applies a SHA1 algorithm on the contents of file and returns the result in lowercase hexadecimal digits.
Required sort order: '0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f' (ASCII order)
3.9.5 Data Format: single line of text with 160 bit binary represented as 40 lowercase hexadecimal digits
3.9.6 Tag: PackageVerificationCode:
(and optionally (excludes: FileName)
)
where FileName is as specified in 6.1.
Example:
PackageVerificationCode: d6a770ba38583ed4bb4525bd96e50461655d2758 (excludes: ./package.spdx)
3.9.7 RDF: spdx:packageVerificationCodeValue
, spdx:packageVerificationCodeExcludedFile
in class spdx:PackageVerificationCode
Example:
<Package rdf:about="...">
<packageVerificationCode>
<PackageVerificationCode>
<packageVerificationCodeValue>
d6a770ba38583ed4bb4525bd96e50461655d2758
</packageVerificationCodeValue>
<packageVerificationCodeExcludedFile>
./package.spdx
</packageVerificationCodeExcludedFile>
</PackageVerificationCode>
</packageVerificationCode>
</Package>
3.10.1 Purpose: This field provides an independently reproducible mechanism that permits unique identification of a specific package that correlates to the data in this SPDX file. This identifier enables a recipient to determine if any file in the original package has been changed. If the SPDX file is to be included in a package, this value should not be calculated. The SHA-1 algorithm will be used to provide the checksum by default.
3.10.2 Intent: Here, by providing a unique identifier of the package, confusion over which version or modification of a specific package the SPDX file references should be eliminated.
3.10.3 Cardinality: Optional, one or many.
3.10.4 Algorithms that can be used: SHA1, SHA256, MD5
3.10.5 Data Format: There are three components, an algorithm identifier(“SHA1”), a colon separator ”:”, and a bit value represented as lowercase hexadecimal digits (appropriate as output to the algorithm).
3.10.6 Tag: PackageChecksum:
Example:
PackageChecksum: SHA1: 85ed0817af83a24ad8da68c2b5094de69833983c
PackageChecksum: SHA256: 11b6d3ee554eedf79299905a98f9b9a04e498210b59f15094c916c91d150efcd
PackageChecksum: MD5: 624c1abb3664f4b35547e7c73864ad24
3.10.7 RDF: properties spdx:algorithm
, spdx:checksumValue
in class spdx:checksum
Example:
<Package rdf:about="...">
<checksum>
<Checksum>
<algorithm rdf:resource="http://spdx.org/rdf/terms#checksumAlgorithm_sha1"/>
<checksumValue>85ed0817af83a24ad8da68c2b5094de69833983c</checksumValue>
</Checksum>
</checksum>
<checksum>
<Checksum>
<algorithm rdf:resource="http://spdx.org/rdf/terms#checksumAlgorithm_sha256"/>
<checksumValue>
11b6d3ee554eedf79299905a98f9b9a04e498210b59f15094c916c91d150efcd
</checksumValue>
</Checksum>
</checksum>
<checksum>
<Checksum>
<algorithm rdf:resource="http://spdx.org/rdf/terms#checksumAlgorithm_md5"/>
<checksumValue>624c1abb3664f4b35547e7c73864ad24</checksumValue>
</Checksum>
</checksum>
</Package>
3.11.1 Purpose: This field provides a place for the SPDX file creator to record a web site that serves as the package's home page. This link can also be used to reference further information about the package referenced by the SPDX file creator.
Use NONE if there is no package home page whatsoever.
Use NOASSERTION if: (i) the SPDX file creator has attempted to but cannot reach a reasonable objective determination; (ii) the SPDX file creator has made no attempt to determine this field; or (iii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
3.11.2 Intent: Here, by providing a link to the package's home page, the SPDX file creator can provide additional information useful for analysis. This saves the recipient of the SPDX file who is looking for more info from having to search for and verify a match between the package and the associated project homepage.
3.11.3 Cardinality: Optional, one.
3.11.4 Data Format: uniform resource locator | “NONE” | “NOASSERTION”
3.11.5 Tag: “PackageHomePage:”
Example:
PackageHomePage: http://ftp.gnu.org/gnu/glibc
3.11.6 RDF: property doap:homepage
in class spdx:Package
Example:
<Package rdf:about="...">
<doap:homepage >http://ftp.gnu.org/gnu/glibc/</doap:homepage> </Package>
3.12.1 Purpose: This field provides a place for the SPDX file creator to record any relevant background information or additional comments about the origin of the package. For example, this field might include comments indicating whether the package was pulled from a source code management system or has been repackaged.
3.12.2 Intent: Here, by providing a comment field, the SPDX file creator can provide additional information to describe any anomalies or discoveries in the determination of the origin of the package.
3.12.3 Cardinality: Optional, one.
3.12.4 Data Format: free form text that can span multiple lines.
In Tag:value format this is delimited by <text> .. </text>
.
3.12.5 Tag: PackageSourceInfo:
Example:
PackageSourceInfo: <text>uses glibc-2_11-branch from git://sourceware.org/git/glibc.git.</text>
3.12.6 RDF: spdx:sourceInfo
Example:
<Package rdf:about="...">
...
<sourceInfo>uses glibc-2_11-branch from git://sourceware.org/git/glibc.git.</sourceInfo>
...
</Package>
3.13.1 Purpose: This field contains the license the SPDX file creator has concluded as governing the package or alternative values, if the governing license cannot be determined.
The options to populate this field are limited to:
A valid SPDX License Expression as defined in Appendix IV;
NONE, if the SPDX file creator concludes there is no license available for this package; or NOASSERTION if:
(i) the SPDX file creator has attempted to but cannot reach a reasonable objective determination; (ii) the SPDX file creator has made no attempt to determine this field; or (iii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
If the Concluded License is not the same as the Declared License, a written explanation should be provided in the Comments on License field (section 3.16). With respect to NOASSERTION, a written explanation in the Comments on License field (section 3.16) is preferred.
3.13.2 Intent: Here, the intent is for the SPDX file creator to analyze the license information in package, and other objective information, e.g., COPYING file, together with the results from any scanning tools, to arrive at a reasonably objective conclusion as to what license governs the package.
3.13.3 Cardinality: Mandatory, one.
3.13.4 Data Format: | “NONE” | “NOASSERTION”
where:
is a valid SPDX License Expression as defined in Appendix IV.
3.13.5 Tag: PackageLicenseConcluded:
Example:
PackageLicenseConcluded: LGPL-2.0
Example:
PackageLicenseConcluded: (LGPL-2.0 OR LicenseRef-3)
3.13.6 RDF: property spdx:licenseConcluded
in class spdx:Package
Example:
<Package rdf:about="...">
...
<licenseConcluded rdf:resource="http://spdx.org/licenses/LGPL-2.0" />
...
</Package>
Example:
<Package rdf:about="...">
...
<licenseConcluded>
<DisjunctiveLicenseSet>
<member rdf:resource="http://spdx.org/licenses/LGPL-2.0" />
<member rdf:resource="LicenseRef-3" />
</DisjunctiveLicenseSet>
</licenseConcluded>
...
</Package>
3.14.1 Purpose: This field is to contain a list of all licenses found in the package. The relationship between licenses (i.e., conjunctive, disjunctive) is not specified in this field – it is simply a listing of all licenses found.
The options to populate this field are limited to:
The SPDX License List short form identifier, if a detected license is on the SPDX License List; A user defined license reference denoted by LicenseRef-[idstring] (for a license not on the SPDX License List); NONE, if no license information is detected in any of the files; or NOASSERTION, if:
(i) the SPDX file creator has made no attempt to determine this field; or (ii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
3.14.2 Intent: Here, the intention is to capture all license information detected in the actual files.
3.14.3 Cardinality: Mandatory, one or many if filesAnalyzed is true or omitted.
Zero (must be omitted) if filesAnalyzed is false.
3.14.4 Data Format: <short form identifier in Appendix I> |
[“DocumentRef-”[idstring]”:”]"LicenseRef"-[idstring] |
| “NONE” | “NOASSERTION”
where:
“DocumentRef-”[idstring] is an optional reference to an external SPDX
document as described in section 2.6
[idstring] is a unique string containing letters, numbers, “.”, or “-”
3.14.5 Tag: PackageLicenseInfoFromFiles:
Example:
PackageLicenseInfoFromFiles: GPL-2.0
PackageLicenseInfoFromFiles: LicenseRef-1
PackageLicenseInfoFromFiles: LicenseRef-2
3.14.6 RDF: property spdx:licenseInfoFromFiles
in class spdx:Package
Example:
<Package rdf:about="...">
...
<licenseInfoFromFiles rdf:resource=" http://spdx.org/licenses/GPL-2.0" />
<licenseInfoFromFiles rdf:resource="#LicenseRef-1" />
<licenseInfoFromFiles rdf:resource="#LicenseRef-2" />
...
</Package>
3.15.1 Purpose: This field lists the licenses that have been declared by the authors of the package. Any license information that does not originate from the package authors, e.g. license information from a third party repository, should not be included in this field.
The options to populate this field are limited to:
A valid SPDX License Expression as defined in Appendix IV; NONE, if the package contains no license information whatsoever; or NOASSERTION if: (i) the SPDX file creator has made no attempt to determine this field; or (ii) the SPDX file creator has intentionally provided no information (no meaning should be implied by doing so).
3.15.2 Intent: This is simply the license identified in text in one or more files (for example COPYING file) in the source code package. This field is not intended to capture license information obtained from an external source, such as the package website. Such information can be included in Concluded License (section 3.13). This field may have multiple Declared Licenses, if multiple licenses are declared at the package level.
3.15.3 Cardinality: Mandatory, one.
3.15.4 Data Format: <SPDX License Expression> | “NONE” | “NOASSERTION”
where:
<SPDX License Expression> is a valid SPDX License Expression as defined in Appendix IV.
3.15.5 Tag: PackageLicenseDeclared:
Example:
PackageLicenseDeclared: LGPL-2.0
Example:
PackageLicenseDeclared: (LGPL-2.0 AND LicenseRef-3)
3.15.6 RDF: property spdx:licenseDeclared
in class spdx:Package
Example:
<Package rdf:about=”...”>
...
<licenseDeclared rdf:resource="http://spdx.org/licenses/LGPL-2.0" />
...
</Package>
Example:
<Package rdf:about="...">
...
<licenseDeclared>
<ConjunctiveLicenseSet>
<member rdf:resource="http://spdx.org/licenses/LGPL-2.0" />
<member rdf:resource="#LicenseRef-3" />
</ConjunctiveLicenseSet>
</licenseDeclared>
...
</Package>
3.16.1 Purpose: This field provides a place for the SPDX file creator to record any relevant background information or analysis that went in to arriving at the Concluded License for a package. If the Concluded License does not match the Declared License or License Information from Files, this should be explained by the SPDX file creator. Its is also preferable to include an explanation here when the Concluded License is NOASSERTION.
3.16.2 Intent: Here, the intent is to provide the recipient of the SPDX file with a detailed explanation of how the Concluded License was determined if it does not match the License Information from the files or the source code package, is marked NOASSERTION, or other helpful information relevant to determining the license of the package.
3.16.3 Cardinality: Optional, one.
3.16.4 Data Format: free form text that can span multiple lines.
In Tag:value format this is delimited by <text> .. </text>
,
in RDF, it is delimited by <licenseComment>
.
3.16.5 Tag: PackageLicenseComments:
Example:
PackageLicenseComments: <text>The license for this project changed with the release of version 1.4.
The version of the project included here post-dates the license change.</text>
3.16.6 RDF: property spdx:licenseComments
in class spdx:Package
Example:
<Package rdf:about="...">
...
<licenseComments>
This package has been shipped in source and binary form.
The binaries were created with gcc 4.5.1 and expect to link to
compatible system run time libraries.
</licenseComments>
...
</Package>
3.17.1 Purpose: Identify the copyright holders of the package, as well as any dates present. This will be a free form text field extracted from package information files. The options to populate this field are limited to:
Any text related to a copyright notice, even if not complete; NONE if the package contains no copyright information whatsoever; or NOASSERTION, if
(i) the SPDX document creator has made no attempt to determine this field; or
(ii) the SPDX document creator has intentionally provided no information (no meaning should be implied by doing so).
3.17.2 Intent: Record any copyright notices for the package.
3.17.3 Cardinality: Mandatory, one.
3.17.4 Data Format: free form text that can span multiple lines | “NONE” | “NOASSERTION”
3.17.5 Tag: PackageCopyrightText:
In Tag:value format multiple lines are delimited by <text> .. </text>
.
Example:
PackageCopyrightText: <text>Copyright 2008-2010 John Smith</text>
3.17.6 RDF: property spdx:copyrightText
in class spdx:Package
Example:
<Package rdf:about="...">
...
<copyrightText>Copyright 2008-2010 John Smith</copyrightText>
...
</Package>
3.18.1 Purpose: This field is a short description of the package.
3.18.2 Intent: Here, the intent is to allow the SPDX file creator to provide concise information about the function or use of the package without having to parse the source code of the actual package.
3.18.3 Cardinality: Optional, one.
3.18.4 Data Format: free form text that can span multiple lines.
3.18.5 Tag: PackageSummary:
In Tag:value format multiple lines are delimited by <text> .. </text>
.
Example:
PackageSummary: <text>GNU C library.</text>
3.18.6 RDF: property spdx:summary
in class spdx:Package
Example:
<Package rdf:about="...">
...
<summary> GNU C library.</summary>
...
</Package>
3.19.1 Purpose: This field is a more detailed description of the package. It may also be extracted from the packages itself.
3.19.2 Intent: Here, the intent is to provide recipients of the SPDX file with a detailed technical explanation of the functionality, anticipated use, and anticipated implementation of the package. This field may also include a description of improvements over prior versions of the package.
3.19.3 Cardinality: Optional, one.
3.19.4 Data Format: free form text than can span multiple lines.
3.19.5 Tag: PackageDescription:
In Tag:value format multiple lines are delimited by <text> .. </text>
.
Example:
PackageDescription: <text>The GNU C Library defines functions that are specified by the ISO C standard,
as well as additional features specific to POSIX and other derivatives of the Unix operating system,
and extensions specific to GNU systems.</text>
3.19.6 RDF: property spdx:description
in class spdx:Package
Example:
<Package rdf:about="...">
...
<description>
The GNU C Library defines functions that are specified by the
ISO C standard, as well as additional features specific to POSIX and other
derivatives of the Unix operating system, and extensions specific to GNU systems.
</description>
...
</Package>
3.20.1 Purpose: This field provides a place for the SPDX file creator to record any general comments about the package being described.
3.20.2 Intent: Here, the intent is to provide the recipient of the SPDX document with more information determined after careful analysis of a package.
3.20.3 Cardinality: Optional, one.
3.20.4 Data Format: free form text that can span multiple lines.
3.20.5 Tag: PackageComment:
In Tag:value format multiple lines are delimited by <text> .. </text>
.
Example:
PackageComment: <text>The package includes several sub-packages; see Relationship information.</text>
3.20.6 RDF: property rdfs:comment
in class spdx:Package
Example:
<Package rdf:about="...">
...
<rdfs:comment>
The package includes several sub-packages; see Relationship information.
</rdfs:comment>
...
</Package>
3.21.1 Purpose: An External Reference allows a Package to reference an external source of additional information, metadata, enumerations, asset identifiers, or downloadable content believed to be relevant to the Package.
3.21.2 Intent: To indicate an outside source of information, metadata enumerations, asset identifiers, or content relevant to the Package, such as a structured naming scheme identifying Packages with known security vulnerabilities.
3.21.3 Cardinality: Optional (one or many)
3.21.4 Data Format: <category> <type> <locator>
where:
<category>
is “SECURITY” | “PACKAGE-MANAGER” | “OTHER”
<type>
is an [idstring] that is defined in Appendix.
<locator>
is the unique string with no spaces necessary to access the package-specific information, metadata, or content within the target location. The format of the locator is subject to constraints defined by the <type>
.
3.21.5 Tag: ExternalRef:
Example:
ExternalRef: SECURITY cpe23Type cpe:2.3:a:pivotal_software:spring_framework:4.1.0:*:*:*:*:*:*:*
ExternalRef: OTHER LocationRef-acmeforge acmecorp/acmenator/4.1.3-alpha
3.21.6 RDF: property target
in class spdx:ExternalRef
Example (for a ‘listed’ location):
<spdx:Package rdf:about="...">
...
<spdx:externalRef>
<spdx:ExternalRef>
<spdx:referenceCategory rdf:resouce=”http://spdx.org/rdf/terms#referenceCategory_packageManager” />
<spdx:referenceType rdf:resource=”http://spdx.org/rdf/refeferences/maven-central” />
<spdx:referenceLocator>org.apache.commons:commons-lang:3.2.1</spdx:referenceLocator>
</spdx:ExternalRef>
</spdx:externalRef>
...
</spdx:package>
Example (for a not ‘listed’ location):
<spdx:Package rdf:about="...">
...
<spdx:externalRef>
<spdx:ExternalRef>
<spdx:referenceCategory rdf:resource="http://spdx.org/rdf/terms#referenceCategory_other" />
<spdx:referenceType rdf:resource=”http://spdx.org/spdxdocs/spdx-tools-v1.2-3F2504E0-4F89-41D3-9A0C-0305E82...LocationRef-acmeforge” />
<spdx:referenceLocator>acmecorp/acmenator/4.1.3-alpha</spdx:referenceLocator>
</spdx:ExternalRef>
</spdx:externalRef>
...
</spdx:package>
The referenceType value for a non-listed location consists of the SPDX document namespace (per section 2.5) followed by a “#” and the category as defined in 3.21.4.
3.22.1 Purpose: To provide human-readable information about the purpose and target of the reference.
3.22.2 Intent: To inform a human consumer why the reference exists, what kind of information, content or metadata can be extracted. The target’s relationship to artifactOf values of files in the package may need to be explained here. If the reference is BINARY, its relationship to PackageDownloadLocation may need to be explained. If the reference is SOURCE, its relationship to PackageDownloadLocation and SourceInformation may need to be explained.
3.22.3 Cardinality: Conditional (Optional, one) for each External Reference.
3.22.4 Data format: Free form text that can span multiple lines.
In Tag:value format this is delimited by <text> .. </text>
, and is expected to follow an External References so that the association can be made.
in RDF, it is delimited by <ExternalRefComment>
.
3.22.5 Tag: ExternalRefComment:
Example:
ExternalRefComment: <text>NIST National Vulnerability Database (NVD) describes
security vulnerabilities (CVEs) which affect Vendor Product Version
acmecorp:acmenator:6.6.6.</text>
3.22.6 RDF: Property rdfs:comment
in class spdx:ExternalRef
<spdx:Package rdf:about="...">
...
<spdx:externalRef>
<spdx:ExternalRef>
<spdx:referenceCategory rdf:resouce=”http://spdx.org/rdf/terms#referenceCategory_packageManager” />
<spdx:referenceType rdf:resource=”http://spdx.org/rdf/refeferences/maven-central” />
<spdx:referenceLocator>org.apache.commons:commons-lang:3.2.1</spdx:referenceLocator>
<rdfs:comment>
NIST National Vulnerability Database (NVD) describes
security vulnerabilities (CVEs) which affect Vendor Product Version
acmecorp:acmenator:6.6.6
</rdfs:comment>
</spdx:ExternalRef>
</spdx:externalRef>
...
</spdx:package>