Module mbed_tools_ci_scripts.report_third_party_ip
Script providing information about licensing and third party IP in order to comply with OpenChain.
The current script uses the SDK provided by the SPDX organisation (i.e. https://github.com/spdx/tools-python). This SDK only supports version 1.2 of the specification and not 2.1. Therefore, some changes will have to be carried out when the later version is supported so that third-party IP gets documented as described by the specification (i.e. with relationships).
Expand source code
#
# Copyright (C) 2020 Arm Mbed. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
"""Script providing information about licensing and third party IP in order to comply with OpenChain.
The current script uses the SDK provided by the SPDX organisation
(i.e. https://github.com/spdx/tools-python).
This SDK only supports version 1.2 of the specification and not 2.1.
Therefore, some changes will have to be carried out when the later version is
supported so that third-party IP gets documented as described by the
specification (i.e. with relationships).
"""
import sys
import argparse
import logging
from pathlib import Path
from typing import Any
from mbed_tools_ci_scripts.spdx_report.spdx_project import SpdxProject
from mbed_tools_ci_scripts.utils.logging import set_log_level, log_exception
from mbed_tools_ci_scripts.utils.package_helpers import CurrentProjectMetadataParser, generate_package_info
logger = logging.getLogger(__name__)
def get_current_spdx_project() -> SpdxProject:
    """Gets information about the current project/package."""
    logger.info("Generating package information.")
    try:
        # Trying to generate the egg for the package but this may fail. If so, continue.
        generate_package_info()
    except Exception as e:
        log_exception(logger, e)
    return SpdxProject(CurrentProjectMetadataParser())
def generate_spdx_project_reports(project: SpdxProject, output_directory: Path) -> SpdxProject:
    """Generates all the SPDX reports for a given project."""
    logger.info("Generating SPDX report.")
    project.generate_tag_value_files(output_directory)
    logger.info("Generating licensing summary.")
    project.generate_licensing_summary(output_directory)
    return project
def generate_spdx_reports(output_directory: Path) -> SpdxProject:
    """Generates all the SPDX reports for the current project."""
    project = get_current_spdx_project()
    return generate_spdx_project_reports(project, output_directory)
def main() -> int:
    """Script CLI."""
    parser = argparse.ArgumentParser(description="Generate licence and third-party IP reports.")
    def convert_to_path(arg: Any) -> Path:
        """Converts argument to a path."""
        return Path(arg)
    parser.add_argument(
        "-o", "--output-dir", help="Output directory where the files are generated", required=True, type=convert_to_path
    )
    parser.add_argument(
        "-v",
        "--verbose",
        action="count",
        default=0,
        help="Verbosity, by default errors are reported.",
    )
    args = parser.parse_args()
    set_log_level(args.verbose)
    try:
        project = generate_spdx_reports(args.output_dir)
        project.check_licence_compliance()
        return 0
    except Exception as e:
        log_exception(logger, e)
        return 1
if __name__ == "__main__":
    sys.exit(main())Functions
- def generate_spdx_project_reports(project: SpdxProject, output_directory: pathlib.Path) ‑> SpdxProject
- 
Generates all the SPDX reports for a given project. Expand source codedef generate_spdx_project_reports(project: SpdxProject, output_directory: Path) -> SpdxProject: """Generates all the SPDX reports for a given project.""" logger.info("Generating SPDX report.") project.generate_tag_value_files(output_directory) logger.info("Generating licensing summary.") project.generate_licensing_summary(output_directory) return project
- def generate_spdx_reports(output_directory: pathlib.Path) ‑> SpdxProject
- 
Generates all the SPDX reports for the current project. Expand source codedef generate_spdx_reports(output_directory: Path) -> SpdxProject: """Generates all the SPDX reports for the current project.""" project = get_current_spdx_project() return generate_spdx_project_reports(project, output_directory)
- def get_current_spdx_project() ‑> SpdxProject
- 
Gets information about the current project/package. Expand source codedef get_current_spdx_project() -> SpdxProject: """Gets information about the current project/package.""" logger.info("Generating package information.") try: # Trying to generate the egg for the package but this may fail. If so, continue. generate_package_info() except Exception as e: log_exception(logger, e) return SpdxProject(CurrentProjectMetadataParser())
- def main() ‑> int
- 
Script CLI. Expand source codedef main() -> int: """Script CLI.""" parser = argparse.ArgumentParser(description="Generate licence and third-party IP reports.") def convert_to_path(arg: Any) -> Path: """Converts argument to a path.""" return Path(arg) parser.add_argument( "-o", "--output-dir", help="Output directory where the files are generated", required=True, type=convert_to_path ) parser.add_argument( "-v", "--verbose", action="count", default=0, help="Verbosity, by default errors are reported.", ) args = parser.parse_args() set_log_level(args.verbose) try: project = generate_spdx_reports(args.output_dir) project.check_licence_compliance() return 0 except Exception as e: log_exception(logger, e) return 1