The MvnFeed CLI is a command line interface to transfer artifacts from one Maven repository into another.
The tool has been developed to help teams use the Azure Artifacts infrastructure until the upstream source for Maven feeds is available.
The CLI downloads artifacts from one repository into a stage directory before uploading them onto the target repository.
To install:
-
Ensure prerequisites are installed:
- Python2 or 3
-
Check out the Git repository;
-
Run the install script:
# python 2 python scripts/dev_setup.py # python 3 python3 scripts/dev_setup.py
-
Verify that the CLI has been installed correctly:
mvnfeed -h
The configuration file for the MvnFeed CLI is stored in the file ~/.mvnfeed/mvnfeed.ini
and can be edited manually, but the CLI also provides methods to add/remove configuration values.
-
set the directory where artifacts will be saved once downloaded:
mvnfeed config stage_dir set --path /tmp/artifacts
-
add a repository:
mvnfeed config repo add \ --name my_devops_feed \ --username my_username --url https://{organization}.pkgs.visualstudio.com/_packaging/{feed}/maven/v1
About authorization: currently only basic auth is supported but if your repository supports other authentication means, edit the configuration file and directly modify the
authorization
value. This value will be passed unmodified in the Authorization HTTP header. -
list the configured repositories:
mvnfeed config repo list central url : http://central.maven.org/maven2 jcenter url : http://jcenter.bintray.com jboss url : https://repository.jboss.org/nexus/content/repositories/releases clojars url : https://repo.clojars.org atlassian url : https://packages.atlassian.com/maven/public google url : https://maven.google.com my_devops_feed url : https://{organization}.pkgs.visualstudio.com/_packaging{feed}/maven/v1
If only a couple of dependencies need to be transferred, you can choose to transfer them one by one:
mvnfeed artifact transfer \
--from=[REPO_NAME] \
--to=[REPO_NAME] \
--name=[GROUP_ID]:[ARTIFACT_ID]:[VERSION] \
--transfer_deps
where:
[REPO_NAME]
is the name of one of the configured repositories;transfer_deps
: when defined, dependencies defined in POM files will also be transferred.
For more than a handful of dependencies, it is best to define them in a file and use the bulk-transfer
command:
artifacts artifact bulk-transfer \
--from=[REPO_NAME] \
--to=[REPO_NAME] \
--filename=[FILENAME] \
--transfer_deps
where:
-
[FILENAME]
is the name of a file listing the artifacts in the following format:{GROUP_ID}:{ARTIFACT_ID}:{TYPE}[:{ARCHITECTURE}]:{VERSION}
-
transfer_deps
: when defined, dependencies defined in POM files will also be transferred.
For example:
org.projectlombok:lombok:1.18.2
com.microsoft.azure:azure-dependencies-bom:pom:1.0.0.M4
org.elasticsearch:elasticsearch:test-jar:tests:2.4.4
io.netty:netty-transport-native-epoll:jar:linux-x86_64:4.1.28.Final
-
detail information about the transfer can be found in the
mvnfeed.log
logfile created in the current directory; -
because it is not possible to delete uploaded artifacts, mvnfeed tries not to be too clever when parsing the POM files (like deducting versions from
dependencyManagement
block and such.) As a result, you may see following output on the console:missing explicit version for jmock:jmock in hamcrest-parent-1.1.pom. Skipping
this means that you will have to look at the given POM file and manually upload the skipped dependency, if necessary.
-
use the
:pom
type to explicitely transfer a BOM file (e.g.com.microsoft.azure:azure-dependencies-bom:pom:1.0.0.M4
)
Because you may encounter a very large number of missing versions, it is advised to first list the exact dependencies that must be transferred.
-
create a Gradle/Maven project that only includes the desired dependencies, with the only caveat that the Gradle/Maven is not using their respective caches;
-
get the list of all transitive dependencies:
# gradle ./gradlew --gradle-user-home . --debug dependencies > dependencies.txt # maven mvn dependency:list -DoutputFile=dependencies.txt
-
use mvnfeed to do some cleanup:
# gradle mvnfeed input cleanup \ --type=gradle \ --input_file=dependencies.txt \ --ouput_file=dependencies_cleanup.txt # maven mvnfeed input cleanup \ --type=maven \ --input_file=dependencies.txt \ --ouput_file=dependencies_cleanup.txt
-
transfer the dependencies (without the
--transfer_deps
flag):artifacts artifact bulk-transfer \ --from=[REPO_NAME] \ --to=[REPO_NAME] \ --filename=dependencies_cleanup.txt
If you have any issues, questions, comments, or feature requests regarding this tool, please file an issue within this Github repo using our contribution guidelines.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.