macaron.slsa_analyzer.build_tool package
The build_tool package contains the supported build tools for Macaron.
Submodules
macaron.slsa_analyzer.build_tool.base_build_tool module
This module contains the BaseBuildTool class to be inherited by other specific Build Tools.
- class macaron.slsa_analyzer.build_tool.base_build_tool.BuildToolCommand
Bases:
TypedDict
This class is an abstraction for build tool commands storing useful contextual data for analysis.
-
command:
list
[str
] The parsed build tool command. This command can be any bash command whose program name is the build tool.
-
command:
- macaron.slsa_analyzer.build_tool.base_build_tool.file_exists(path, file_name)
Return True if a file exists in a directory.
This method searches in the directory recursively.
- class macaron.slsa_analyzer.build_tool.base_build_tool.RuntimeOptions(build_timeout=600)
Bases:
object
The class for build tool runtime configurations read from defaults.ini.
Note that Macaron uses the options in this class to “run” a build tool.
- __init__(build_timeout=600)
- class macaron.slsa_analyzer.build_tool.base_build_tool.BaseBuildTool(name, language, purl_type)
Bases:
ABC
This abstract class is used to implement Build Tools.
- __init__(name, language, purl_type)
Initialize instance.
- Parameters:
name (str) – The name of this build tool.
language (BuildLanguage) – The name of the language used by the programs built by the build tool.
purl_type (str) – The type field of a PackageURL.
- abstract is_detected(repo_path)
Return True if this build tool is used in the target repo.
- abstract prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
This method will return False if there is any errors happened during operation.
- abstract get_dep_analyzer()
Create a DependencyAnalyzer for the build tool.
- Returns:
The DependencyAnalyzer object.
- Return type:
- get_build_dirs(repo_path)
Find directories in the repository that have their own build scripts.
This is especially important for applications that consist of multiple services.
- serialize_to_json(cmd)
Convert a list of values to a json-encoded string so that it is easily parsable by later consumers.
- is_build_command(cmd)
Determine if the command is a build tool command.
- match_cmd_args(cmd, tools, args)
Check if the build command matches any of the tools and the command-line arguments.
If build command’s first element, which is the program name matches any of the tools names and any of its arguments match any of the arguments in args, this function returns True.
- Parameters:
- Returns:
True if the provided command matches the tool and arguments.
- Return type:
- infer_confidence_deploy_workflow(ci_path, provenance_workflow=None)
Infer the confidence level for the deploy CI workflow.
- Parameters:
- Returns:
The confidence level for the deploy command.
- Return type:
- infer_confidence_deploy_command(cmd, provenance_workflow=None)
Infer the confidence level for the deploy command.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
provenance_workflow (str | None) – The relative path to the root CI file that is captured in a provenance or None if provenance is not found.
- Returns:
The confidence level for the deploy command.
- Return type:
- is_deploy_command(cmd, excluded_configs=None, provenance_workflow=None)
Determine if the command is a deploy command.
A deploy command usually performs multiple tasks, such as compilation, packaging, and publishing the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
provenance_workflow (str | None) – The relative path to the root CI file that is captured in a provenance or None if provenance is not found.
- Returns:
Return True along with the inferred confidence level if the command is a deploy tool command.
- Return type:
- is_package_command(cmd, excluded_configs=None)
Determine if the command is a packaging command.
A packaging command usually performs multiple tasks, such as compilation and creating the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
- Returns:
Return True along with the inferred confidence level if the command is a build tool command.
- Return type:
macaron.slsa_analyzer.build_tool.docker module
This module contains the Docker class which inherits BaseBuildTool.
This module is used to work with repositories that use Docker as a build tool.
- class macaron.slsa_analyzer.build_tool.docker.Docker
Bases:
BaseBuildTool
This class contains the information of Docker when used as a build tool.
- __init__()
Initialize instance.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Make necessary preparations for using this build tool.
- get_dep_analyzer()
Create a DependencyAnalyzer for the Docker build tool. Currently unimplemented.
- Returns:
The NoneDependencyAnalyser object.
- Return type:
NoneDependencyAnalyser
- Raises:
macaron.slsa_analyzer.build_tool.go module
This module contains the Go class which inherits BaseBuildTool.
This module is used to work with repositories that have Go.
- class macaron.slsa_analyzer.build_tool.go.Go
Bases:
BaseBuildTool
This class contains the information of the Go build tool.
- __init__()
Initialize instance.
- Parameters:
name (str) – The name of this build tool.
language (BuildLanguage) – The name of the language used by the programs built by the build tool.
purl_type (str) – The type field of a PackageURL.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
Go doesn’t require preparation, so return true.
- get_dep_analyzer()
Create a DependencyAnalyzer for the build tool.
- Returns:
The DependencyAnalyzer object.
- Return type:
macaron.slsa_analyzer.build_tool.gradle module
This module contains the Gradle class which inherits BaseBuildTool.
This module is used to work with repositories that use Gradle build tool.
- class macaron.slsa_analyzer.build_tool.gradle.Gradle
Bases:
BaseBuildTool
This class contains the information of the Gradle build tool.
- __init__()
Initialize instance.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
This method will return False if there is any errors happened during operation.
- get_dep_analyzer()
Create a DependencyAnalyzer for the Gradle build tool.
- Returns:
The CycloneDxGradle object.
- Return type:
- Raises:
- get_gradle_exec(repo_path)
Get the Gradle executable for the repo.
- get_group_id(gradle_exec, project_path)
Get the group id of a Gradle project.
A Gradle project is a directory containing a
build.gradle
file. According to the Gradle’s documentation, there is a one-to-one mapping between a “project” and abuild.gradle
file. See: https://docs.gradle.org/current/javadoc/org/gradle/api/Project.html.
macaron.slsa_analyzer.build_tool.language module
This module contains abstractions for build languages.
- class macaron.slsa_analyzer.build_tool.language.BuildLanguage(value, names=None, *, module=None, qualname=None, type=None, start=1, boundary=None)
-
The supported build languages.
- JAVA = 'java'
- PYTHON = 'python'
- GO = 'go'
- JAVASCRIPT = 'javascript'
- DOCKER = 'docker'
macaron.slsa_analyzer.build_tool.maven module
This module contains the Maven class which inherits BaseBuildTool.
This module is used to work with repositories that use Maven build tool.
- class macaron.slsa_analyzer.build_tool.maven.Maven
Bases:
BaseBuildTool
This class contains the information of the Maven build tool.
- __init__()
Initialize instance.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
This method will return False if there is any errors happened during operation.
- get_dep_analyzer()
Create a DependencyAnalyzer for the Maven build tool.
- Returns:
The CycloneDxMaven object.
- Return type:
- Raises:
macaron.slsa_analyzer.build_tool.npm module
This module contains the NPM class which inherits BaseBuildTool.
This module is used to work with repositories that use npm/pnpm as its build tool.
- class macaron.slsa_analyzer.build_tool.npm.NPM
Bases:
BaseBuildTool
This class contains the information of the npm/pnpm build tool.
- __init__()
Initialize instance.
- Parameters:
name (str) – The name of this build tool.
language (BuildLanguage) – The name of the language used by the programs built by the build tool.
purl_type (str) – The type field of a PackageURL.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
npm/pnpm doesn’t require preparation, so return true.
- get_dep_analyzer()
Create a DependencyAnalyzer for the build tool.
- Returns:
The DependencyAnalyzer object.
- Return type:
- is_deploy_command(cmd, excluded_configs=None, provenance_workflow=None)
Determine if the command is a deploy command.
A deploy command usually performs multiple tasks, such as compilation, packaging, and publishing the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
provenance_workflow (str | None) – The relative path to the root CI file that is captured in a provenance or None if provenance is not found.
- Returns:
Return True along with the inferred confidence level if the command is a deploy tool command.
- Return type:
- is_package_command(cmd, excluded_configs=None)
Determine if the command is a packaging command.
A packaging command usually performs multiple tasks, such as compilation and creating the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
- Returns:
Return True along with the inferred confidence level if the command is a build tool command.
- Return type:
macaron.slsa_analyzer.build_tool.pip module
This module contains the Pip class which inherits BaseBuildTool.
This module is used to work with repositories that use pip for dependency management.
- class macaron.slsa_analyzer.build_tool.pip.Pip
Bases:
BaseBuildTool
This class contains the information of the pip build tool.
- __init__()
Initialize instance.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
This method returns False on errors. Pip doesn’t require any preparation, therefore this method always returns True.
- get_dep_analyzer()
Create a DependencyAnalyzer for the build tool.
- Returns:
The DependencyAnalyzer object.
- Return type:
- is_deploy_command(cmd, excluded_configs=None, provenance_workflow=None)
Determine if the command is a deploy command.
A deploy command usually performs multiple tasks, such as compilation, packaging, and publishing the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
provenance_workflow (str | None) – The relative path to the root CI file that is captured in a provenance or None if provenance is not found.
- Returns:
Return True along with the inferred confidence level if the command is a deploy tool command.
- Return type:
- is_package_command(cmd, excluded_configs=None)
Determine if the command is a packaging command.
A packaging command usually performs multiple tasks, such as compilation and creating the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
- Returns:
Return True along with the inferred confidence level if the command is a build tool command.
- Return type:
macaron.slsa_analyzer.build_tool.poetry module
This module contains the Poetry class which inherits BaseBuildTool.
This module is used to work with repositories that use Poetry for dependency management.
- class macaron.slsa_analyzer.build_tool.poetry.Poetry
Bases:
BaseBuildTool
This class contains the information of the poetry build tool.
- __init__()
Initialize instance.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
This method returns False on errors. Poetry doesn’t require any preparation, therefore this method always returns True.
- get_dep_analyzer()
Create a DependencyAnalyzer for the build tool.
- Returns:
The DependencyAnalyzer object.
- Return type:
- is_deploy_command(cmd, excluded_configs=None, provenance_workflow=None)
Determine if the command is a deploy command.
A deploy command usually performs multiple tasks, such as compilation, packaging, and publishing the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
provenance_workflow (str | None) – The relative path to the root CI file that is captured in a provenance or None if provenance is not found.
- Returns:
Return True along with the inferred confidence level if the command is a deploy tool command.
- Return type:
- is_package_command(cmd, excluded_configs=None)
Determine if the command is a packaging command.
A packaging command usually performs multiple tasks, such as compilation and creating the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
- Returns:
Return True along with the inferred confidence level if the command is a build tool command.
- Return type:
macaron.slsa_analyzer.build_tool.yarn module
This module contains the Yarn class which inherits BaseBuildTool.
This module is used to work with repositories that use Yarn as its build tool.
- class macaron.slsa_analyzer.build_tool.yarn.Yarn
Bases:
BaseBuildTool
This class contains the information of the yarn build tool.
- __init__()
Initialize instance.
- Parameters:
name (str) – The name of this build tool.
language (BuildLanguage) – The name of the language used by the programs built by the build tool.
purl_type (str) – The type field of a PackageURL.
- is_detected(repo_path)
Return True if this build tool is used in the target repo.
- prepare_config_files(wrapper_path, build_dir)
Prepare the necessary wrapper files for running the build.
yarn doesn’t require preparation, so return true.
- get_dep_analyzer()
Create a DependencyAnalyzer for the build tool.
- Returns:
The DependencyAnalyzer object.
- Return type:
- is_deploy_command(cmd, excluded_configs=None, provenance_workflow=None)
Determine if the command is a deploy command.
A deploy command usually performs multiple tasks, such as compilation, packaging, and publishing the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
provenance_workflow (str | None) – The relative path to the root CI file that is captured in a provenance or None if provenance is not found.
- Returns:
Return True along with the inferred confidence level if the command is a deploy tool command.
- Return type:
- is_package_command(cmd, excluded_configs=None)
Determine if the command is a packaging command.
A packaging command usually performs multiple tasks, such as compilation and creating the artifact. This function filters the build tool commands that are called from the configuration files provided as input.
- Parameters:
cmd (BuildToolCommand) – The build tool command object.
excluded_configs (list[str] | None) – Build tool commands that are called from these configuration files are excluded.
- Returns:
Return True along with the inferred confidence level if the command is a build tool command.
- Return type: