
org.apache.camel.main.console.DependencyDownloaderConsole Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.main.console;
import java.util.Map;
import org.apache.camel.main.download.DependencyDownloaderClassLoader;
import org.apache.camel.main.download.DownloadRecord;
import org.apache.camel.main.download.MavenDependencyDownloader;
import org.apache.camel.spi.annotations.DevConsole;
import org.apache.camel.support.console.AbstractDevConsole;
import org.apache.camel.util.TimeUtils;
import org.apache.camel.util.json.JsonArray;
import org.apache.camel.util.json.JsonObject;
@DevConsole(name = "dependency-downloader", group = "camel-jbang", displayName = "Maven Dependency Downloader",
description = "Displays information about dependencies downloaded at runtime")
public class DependencyDownloaderConsole extends AbstractDevConsole {
public DependencyDownloaderConsole() {
super("camel-jbang", "dependency-downloader", "Maven Dependency Downloader",
"Displays information about dependencies downloaded at runtime");
}
@Override
protected String doCallText(Map options) {
StringBuilder sb = new StringBuilder();
MavenDependencyDownloader downloader = getCamelContext().hasService(MavenDependencyDownloader.class);
if (downloader != null) {
sb.append("Offline: ").append(!downloader.isDownload());
sb.append("\nFresh: ").append(downloader.isFresh());
sb.append("\nVerbose: ").append(downloader.isVerbose());
if (downloader.getRepositories() != null) {
sb.append("\nExtra Repositories: ").append(downloader.getRepositories());
}
sb.append("\n");
sb.append("\nDownloads:");
for (DownloadRecord r : downloader.downloadRecords()) {
sb.append("\n ").append(String.format("%s:%s:%s (took: %s) from: %s@%s",
r.groupId(), r.artifactId(), r.version(), TimeUtils.printDuration(r.elapsed(), true), r.repoId(),
r.repoUrl()));
}
}
ClassLoader cl = getCamelContext().getApplicationContextClassLoader();
if (cl instanceof DependencyDownloaderClassLoader ddcl) {
sb.append("\n\nDependencies:");
String cp = String.join("\n ", ddcl.getDownloaded());
sb.append("\n ").append(cp).append("\n");
}
return sb.toString();
}
@Override
protected JsonObject doCallJson(Map options) {
JsonObject root = new JsonObject();
ClassLoader cl = getCamelContext().getApplicationContextClassLoader();
if (cl instanceof DependencyDownloaderClassLoader) {
DependencyDownloaderClassLoader ddcl = (DependencyDownloaderClassLoader) cl;
String[] cp = ddcl.getDownloaded().toArray(new String[0]);
root.put("dependencies", cp);
}
MavenDependencyDownloader downloader = getCamelContext().hasService(MavenDependencyDownloader.class);
if (downloader != null) {
JsonArray arr = new JsonArray();
root.put("offline", !downloader.isDownload());
root.put("fresh", downloader.isFresh());
root.put("verbose", downloader.isVerbose());
root.put("repos", downloader.getRepositories());
root.put("downloads", arr);
for (DownloadRecord r : downloader.downloadRecords()) {
JsonObject jo = new JsonObject();
arr.add(jo);
jo.put("groupId", r.groupId());
jo.put("artifactId", r.artifactId());
jo.put("version", r.version());
jo.put("elapsed", r.elapsed());
jo.put("repoId", r.repoId());
jo.put("repoUrl", r.repoUrl());
}
}
return root;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy