https://github.com/assert-kth/deptrim
DepTrim automatically specializes the software supply chain of dependencies in Maven projects https://arxiv.org/pdf/2302.08370
Science Score: 26.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
✓.zenodo.json file
Found .zenodo.json file -
○DOI references
-
○Academic publication links
-
○Academic email domains
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (6.6%) to scientific vocabulary
Keywords
Repository
DepTrim automatically specializes the software supply chain of dependencies in Maven projects https://arxiv.org/pdf/2302.08370
Basic Info
Statistics
- Stars: 15
- Watchers: 11
- Forks: 3
- Open Issues: 13
- Releases: 3
Topics
Metadata Files
README.md
DepTrim 
What is DepTrim?
DepTrim is a Maven plugin that automatically specializes the dependencies of a project. The objective is hardening the software supply chain of third-party dependencies of a project by using dependencies that only contain the classes and interfaces that are actually necessary to build the project. Relying on specialized variants of dependencies is good for security, as it reduces the attack surface of the project, and good for performance, as it reduces the size of the final artifact.
After running DepTrim, a directory named libs-specialized is created in the root of the project.
This directory contains the specialized variants of all the dependencies necessary to build the project (inc. direct and transitive dependencies).
DepTrim can also create a specialized POM file, named pom-specialized.xml.
This specialized POM uses the specialized variants of the dependencies instead of the original dependencies.
DepTrim deploys the specialized variants of the dependencies in the local Maven repository.
NOTE: DepTrim does not modify the original source code of the project nor its original pom.xml.
Usage
Run DepTrim directly from the command line as follows:
```bash cd {PATHTOMAVEN_PROJECT}
First, compile source and test files of the project.
mvn compile
mvn compiler:testCompile
Then, run the latest version of DepTrim.
mvn se.kth.castor:deptrim-maven-plugin:0.1.1:deptrim -DcreateSinglePomSpecialized=true ```
Alternatively, configure the original pom.xml file of the project to run DepTrim as part of the build as follows:
xml
<plugin>
<groupId>se.kth.castor</groupId>
<artifactId>deptrim-maven-plugin</artifactId>
<version>0.1.1</version>
<executions>
<execution>
<goals>
<goal>deptrim</goal>
</goals>
<configurations>
<createSinglePomSpecialized>true</createSinglePomSpecialized>
</configurations>
</execution>
</executions>
</plugin>
In both cases, a directory name libs-specialized will be created in the root of the project, together with a file named pom-specialized.xml, which uses the specialized variants of the dependencies.
Optional parameters
The deptrim-maven-plugin accepts the following additional parameters.
| Name | Type | Description |
|:----------------------------|:-------------:|:-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <specializeDependencies> | Set<String> | Add a list of dependencies, identified by their coordinates, to be specialized by DepTrim. Dependency format is: groupId:artifactId:version:scope. An empty string indicates that all the dependencies in the dependency tree of the project will be specialized (default). |
| <ignoreDependencies> | Set<String> | Add a list of dependencies, identified by their coordinates, to be ignored by DepTrim during the analysis. This is useful to override incomplete result caused by bytecode-level static analysis. Dependency format is: groupId:artifactId:version:scope. |
| <ignoreScopes> | Set<String> | Add a list of scopes, to be ignored by DepTrim during the analysis. Useful to not analyze dependencies with scopes that are not needed at runtime. Valid scopes are: compile, provided, test, runtime, system, import. An empty string indicates no scopes (default). |
| <createSinglePomSpecialized> | boolean | If this is true, DepTrim creates a specialized version of the POM file in the root of the project, called pom-specialized.xml, which points to the variant of the specialized the dependencies. Default value is: false. |
| <createDependencySpecializedPerPom> | boolean | If this is true, DepTrim creates one specialized version of the POM file per specialized dependency, called pom-specialized-x-y.xml, where x is an integer identifying a specialized dependency, and y is the total number of specialized dependencies. Default value is: false. |
| <createAllPomSpecialized> | boolean | If this is true, DepTrim creates all the combinations of specialized version of the original POM in the root of the project (i.e., $2^y$ POM files will be created). Name format is pom-specialized-n-x-y.xml, where n is the combination number, x is the number of specialized dependencies in this combination, and y is the total number of specialized dependencies. Default value is: false. |
| <verboseMode> | boolean | Run DepTrim in verbose mode. Default value is: false. |
| <skipDepTrim> | boolean | Skip plugin execution completely. Default value is: false. |
How does DepTrim works?
DepTrim runs before executing during the pre-package phase of the Maven build lifecycle.
DepTrim relies on depclean-core to statically collects all the types used by the project under analysis, as well as in its dependencies.
With this information, DepTrim removes all the types in the dependencies that are not used by the project.
DepTrim also creates a directory named libs-specialized in the root of the project, which contains the specialized versions of the dependencies.
DepTrim creates a new pom-specialized.xml file that contains only the specialized versions of the dependencies.
The pom-specialized.xml is created following these steps:
- Identify all used dependencies and add them as direct dependencies.
- For the used dependencies, remove the types (i.e., compiled classes and interfaces) that are not used by the project.
- Deploy the modified dependencies in the local Maven repository.
- Create a
pom-specialized.xmlso that it uses the specialized variants of the dependencies located in the local Maven repository.
Known limitations
DepTrim needs to know all the types used by the project under analysis, as well as in its dependencies. This is a challenging task, as it requires "seeing" all the project's codebase. In particular, it is not possible to detect the usage of dynamic Java features, such as reflection, dynamic proxies, or custom class loaders, in Java. This necessitates both a thorough understanding of Java's dynamic features and a careful examination of the project's codebase. To detect the utilization of dynamic features within a Java application, we recommend the use of the GraalVM Tracing Agent.
bash
java -agentlib:native-image-agent=config-output-dir=/path/to/config-dir/ -jar yourApp.jar
By running your application with the agent, it will generate a configuration directory (/path/to/config-dir/) containing the files that describe the observed dynamic behavior.
This useful for specialization tasks, e.g., when specializing dependencies that could be accessed dynamically and lack complete a priori knowledge about all possible dynamic behaviors.
While DepTrim aims to streamline the dependency-trimming process, understanding its limitations and employing additional tools like the GraalVM Tracing Agent can help enhance the process. However, note that certain dynamic behaviors, such as the implications of multi-threading or just-in-time (JIT) compilation, may be too subtle or intricate to be detected readily.
Installing and building from source
Prerequisites:
- Java OpenJDK 17 or above
- Apache Maven
In a terminal, clone the repository and switch to the cloned folder:
bash
git clone https://github.com/castor-software/deptrim.git
cd deptrim
Then run the following Maven command to build the application and install the plugin locally:
bash
mvn clean install
License
Distributed under the MIT License. See LICENSE for more information.
Funding
DepTrim is partially funded by the Wallenberg Autonomous Systems and Software Program (WASP).
Owner
- Name: ASSERT
- Login: ASSERT-KTH
- Kind: organization
- Location: Sweden
- Website: https://github.com/ASSERT-KTH/
- Repositories: 87
- Profile: https://github.com/ASSERT-KTH
assertEquals("Research group at KTH Royal Institute of Technology, Stockholm, Sweden", description);
GitHub Events
Total
- Issues event: 1
- Watch event: 1
- Delete event: 2
- Push event: 39
- Pull request event: 3
- Fork event: 1
Last Year
- Issues event: 1
- Watch event: 1
- Delete event: 2
- Push event: 39
- Pull request event: 3
- Fork event: 1
Dependencies
- actions/cache v3 composite
- actions/checkout v3 composite
- actions/setup-java v3 composite
- codecov/codecov-action v3 composite
- actions/checkout v3 composite
- actions/create-release v1 composite
- actions/setup-java v3 composite
- org.apache.maven.plugin-tools:maven-plugin-annotations 3.6.4 provided
- org.apache.maven.shared:maven-dependency-tree 3.2.1 provided
- org.apache.maven:maven-core 3.8.5 provided
- org.apache.maven:maven-plugin-api 3.8.5 provided
- org.apache.maven:maven-project 3.0-alpha-2 provided
- org.projectlombok:lombok 1.18.24 provided
- org.slf4j:slf4j-api 2.0.5
- se.kth.castor:depclean-core 2.0.5
- se.kth.castor:depclean-maven-plugin 2.0.5
- com.soebes.itf.jupiter.extension:itf-assertj 0.11.0 test
- com.soebes.itf.jupiter.extension:itf-extension-maven 0.11.0 test
- com.soebes.itf.jupiter.extension:itf-jupiter-extension 0.11.0 test
- org.assertj:assertj-core 3.23.1 test
- org.junit.jupiter:junit-jupiter-api 5.9.0 test
- org.junit.jupiter:junit-jupiter-engine 5.9.0 test
- org.junit.jupiter:junit-jupiter-params 5.9.0 test
- org.junit.vintage:junit-vintage-engine 5.9.0 test
- org.mockito:mockito-core 4.11.0 test
- com.fasterxml.jackson.core:jackson-databind 2.12.2
- com.google.guava:guava 17.0
- commons-io:commons-io 2.11.0
- com.fasterxml.jackson.core:jackson-databind 2.12.2
- com.google.guava:guava 17.0
- commons-io:commons-io 2.11.0
- com.fasterxml.jackson.core:jackson-databind 2.12.2
- com.google.guava:guava 17.0
- commons-io:commons-io 2.11.0
- commons-codec:commons-codec 1.15
- commons-io:commons-io 2.8.0
- com.jcabi:jcabi-xml 0.18.1 test
- org.junit.jupiter:junit-jupiter-api 5.9.0 test
- org.junit.jupiter:junit-jupiter-engine 5.9.0 test
- org.junit.jupiter:junit-jupiter-params 5.9.0 test
- org.junit.vintage:junit-vintage-engine 5.9.0 test
- com.jcabi:jcabi-manifests 1.1
- commons-codec:commons-codec 1.15
- commons-io:commons-io 2.8.0