Skip to content

Commit

Permalink
Persist manifest name and add channel versions command
Browse files Browse the repository at this point in the history
  • Loading branch information
spyrkob committed Oct 18, 2023
1 parent 45531f2 commit 5325eae
Show file tree
Hide file tree
Showing 12 changed files with 220 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ public static CommandLine createCommandLine(CliConsole console, String[] args, A
channelCmd.addSubcommand(new ChannelAddCommand(console, actionFactory));
channelCmd.addSubcommand(new ChannelRemoveCommand(console, actionFactory));
channelCmd.addSubcommand(new ChannelCommand.ChannelListCommand(console, actionFactory));
channelCmd.addSubcommand(new ChannelCommand.ChannelVersionCommand(console, actionFactory));
channelCmd.addSubcommand(new ChannelInitializeCommand(console, actionFactory));
channelCmd.addSubcommand(new ChannelPromoteCommand(console, actionFactory));

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -623,4 +623,8 @@ default String quitGenerating() {
default String metadataExistsAlready(Path path, String distName) {
return format(bundle.getString("prospero.update.subscribe.meta.exists"), path, distName);
}

default String serverVersionsHeader() {
return bundle.getString("prospero.channels.versions.header");
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
import org.wildfly.prospero.cli.CliMessages;
import org.wildfly.prospero.cli.ReturnCodes;
import org.wildfly.prospero.cli.printers.ChannelPrinter;
import org.wildfly.prospero.metadata.ManifestVersionRecord;
import picocli.CommandLine;

@CommandLine.Command(name = CliConstants.Commands.CHANNEL)
Expand Down Expand Up @@ -78,5 +79,46 @@ public Integer call() throws Exception {
}
}

@CommandLine.Command(name = CliConstants.Commands.VERSIONS)
public static class ChannelVersionCommand extends AbstractCommand {

protected static final String PREFIX = " * ";
@CommandLine.Option(names = CliConstants.DIR)
private Optional<Path> directory;

public ChannelVersionCommand(CliConsole console, ActionFactory actionFactory) {
super(console, actionFactory);
}

@Override
public Integer call() throws Exception {
final Path installationDir = determineInstallationDirectory(directory);

console.println(CliMessages.MESSAGES.serverVersionsHeader());
try (MetadataAction metadataAction = actionFactory.metadataActions(installationDir)) {
final ManifestVersionRecord channelVersions = metadataAction.getChannelVersions();
for (ManifestVersionRecord.MavenManifest mavenManifest : channelVersions.getMavenManifests()) {
if (mavenManifest.getDescription() != null) {
console.println(PREFIX + mavenManifest.getDescription());
} else {
console.println(PREFIX + buildManifestGav(mavenManifest));
}
}
for (ManifestVersionRecord.UrlManifest urlManifest : channelVersions.getUrlManifests()) {
if (urlManifest.getDescription() != null) {
console.println(PREFIX + urlManifest.getDescription());
} else {
console.println(PREFIX + String.format("%s [%s]", urlManifest.getUrl(), urlManifest.getHash()));
}
}
}
return ReturnCodes.SUCCESS;
}

private static String buildManifestGav(ManifestVersionRecord.MavenManifest mavenManifest) {
return String.format("%s:%s [%s]", mavenManifest.getGroupId(), mavenManifest.getArtifactId(), mavenManifest.getVersion());
}
}


}
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ private CliConstants() {
public static final class Commands {


protected static final String VERSIONS = "versions";

private Commands() {
}

Expand Down
2 changes: 2 additions & 0 deletions prospero-cli/src/main/resources/UsageMessages.properties
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ ${prospero.dist.name}.channel.list.usage.header = Lists the channels used by t
${prospero.dist.name}.channel.remove.usage.header = Unsubscribes the installation from a channel.
${prospero.dist.name}.channel.initialize.usage.header = Add a custom channel to be used by the server
${prospero.dist.name}.channel.promote.usage.header = Promote a bundle of artifacts to a custom repository
${prospero.dist.name}.channel.versions.usage.header = Displays currently used versions of manifests from registered channels.

${prospero.dist.name}.clone.usage.header = Exports installation details required to recreate a server.
${prospero.dist.name}.clone.export.usage.header = Exports the installation details that can be used to recreate a server.
Expand Down Expand Up @@ -299,6 +300,7 @@ prospero.export.done=Export complete

prospero.channels.list.header=Server %s is subscribed to following channels:%n
prospero.channels.add.header=Subscribing %s to channel %s%n
prospero.channels.versions.header=Installed server components:
prospero.channels.added=Channel '%s' added.
prospero.channels.remove.header=Unsubscribing %s from channel %s%n
prospero.channels.removed=Channel '%s' removed.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,15 @@ public void testListInvalidInstallationDir() {
.getMessage()));
}

@Test
public void testVersionInvalidInstallationDir() {
int exitCode = commandLine.execute(CliConstants.Commands.CHANNEL, CliConstants.Commands.VERSIONS);

Assert.assertEquals(ReturnCodes.INVALID_ARGUMENTS, exitCode);
assertTrue(getErrorOutput().contains(CliMessages.MESSAGES.invalidInstallationDir(ChannelCommand.currentDir())
.getMessage()));
}

@Test
public void testAddEmptyRepository() {
int exitCode = commandLine.execute(CliConstants.Commands.CHANNEL, CliConstants.Commands.ADD,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
import org.wildfly.prospero.ProsperoLogger;
import org.wildfly.prospero.api.InstallationMetadata;
import org.wildfly.prospero.api.exceptions.MetadataException;
import org.wildfly.prospero.metadata.ManifestVersionRecord;
import org.wildfly.prospero.model.ProsperoConfig;

/**
Expand Down Expand Up @@ -90,6 +91,10 @@ public List<Channel> getChannels() throws MetadataException {
return new ArrayList<>(installationMetadata.getProsperoConfig().getChannels());
}

public ManifestVersionRecord getChannelVersions() {
return installationMetadata.getManifestVersions().orElse(new ManifestVersionRecord());
}

@Override
public void close() {
this.installationMetadata.close();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -394,7 +394,7 @@ public void updateProsperoConfig(ProsperoConfig config) throws MetadataException
gitStorage.recordConfigChange();
}

public Optional<ManifestVersionRecord> getManifestVersions() throws IOException {
public Optional<ManifestVersionRecord> getManifestVersions() {
return manifestVersion;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -215,6 +215,21 @@ public String generateApplyRevertCommand(Path scriptHome, Path candidatePath, Os
return escape(scriptHome.resolve(cliProvider.getScriptName(shell))) + " " + cliProvider.getApplyRevertCommand(installationDir, candidatePath);
}

// TODO: uncomment the implementation when upgrading to new API version
// @Override
// public Collection<ManifestVersion> getInstalledVersions() throws MetadataException {
// try (MetadataAction metadataAction = actionFactory.getMetadataAction()) {
// final ManifestVersionRecord versionRecord = metadataAction.getChannelVersions();
// return Stream.concat(
// versionRecord.getMavenManifests().stream()
// .map(m->new ManifestVersion(m.getGroupId()+":"+m.getArtifactId(), m.getDescription(), m.getVersion(), ManifestVersion.Type.MAVEN)),
// versionRecord.getUrlManifests().stream()
// .map(m->new ManifestVersion(m.getUrl(), m.getDescription(), m.getHash(), ManifestVersion.Type.URL))
// )
// .collect(Collectors.toList());
// }
// }

private String escape(Path absolutePath) {
return "\"" + absolutePath.toString() + "\"";
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.ObjectMapper;
Expand All @@ -33,19 +34,32 @@
import java.util.List;
import java.util.Optional;

@JsonIgnoreProperties(ignoreUnknown = true)
public class ManifestVersionRecord {

@JsonIgnoreProperties(ignoreUnknown = true)
public static class MavenManifest {

private final String description;
private String groupId;
private String artifactId;
private String version;

@Deprecated
public MavenManifest(String groupId,
String artifactId,
String version) {
this(groupId, artifactId, version, null);
}

public MavenManifest(@JsonProperty("groupId") String groupId,
@JsonProperty("artifactId") String artifactId,
@JsonProperty("version") String version) {
@JsonProperty("version") String version,
@JsonProperty(value = "description", required = false) String description) {
this.groupId = groupId;
this.artifactId = artifactId;
this.version = version;
this.description = description;
}

public String getGroupId() {
Expand All @@ -59,20 +73,37 @@ public String getArtifactId() {
public String getVersion() {
return version;
}

@JsonInclude(JsonInclude.Include.NON_NULL)
public String getDescription() {
return description;
}

@JsonIgnore
public String getSummary() {
return String.format("[%s:%s::%s]", groupId, artifactId, version);
}

}

@JsonIgnoreProperties(ignoreUnknown = true)
public static class UrlManifest {

private String url;
private String hash;
public UrlManifest(@JsonProperty("url") String url, @JsonProperty("hash") String hash) {
private String description;

@Deprecated
public UrlManifest(String url, String hash) {
this.url = url;
this.hash = hash;
this.description = null;
}

public UrlManifest(@JsonProperty("url") String url, @JsonProperty("hash") String hash, @JsonProperty("description") String description) {
this.url = url;
this.hash = hash;
this.description = description;
}

public String getUrl() {
Expand All @@ -83,13 +114,19 @@ public String getHash() {
return hash;
}

@JsonInclude(JsonInclude.Include.NON_NULL)
public String getDescription() {
return description;
}

@JsonIgnore
public String getSummary() {
return String.format("[%s::%s]", url, hash);
}

}

@JsonIgnoreProperties(ignoreUnknown = true)
public static class NoManifest {

private List<String> repos;
Expand All @@ -114,21 +151,26 @@ public String getSummary() {
}

}

private String schemaVersion;
private List<MavenManifest> mavenManifests = new ArrayList<>();

private List<UrlManifest> urlManifests = new ArrayList<>();
private List<NoManifest> noManifests = new ArrayList<>();

@JsonCreator
public ManifestVersionRecord(@JsonProperty("maven") List<MavenManifest> mavenManifests,
public ManifestVersionRecord(@JsonProperty("schemaVersion") String schemaVersion,
@JsonProperty("maven") List<MavenManifest> mavenManifests,
@JsonProperty("url") List<UrlManifest> urlManifests,
@JsonProperty("open") List<NoManifest> noManifests) {
this.schemaVersion = schemaVersion;
this.mavenManifests = mavenManifests==null?Collections.emptyList():mavenManifests;
this.urlManifests = urlManifests==null?Collections.emptyList():urlManifests;
this.noManifests = noManifests==null?Collections.emptyList():noManifests;
}

public ManifestVersionRecord() {
this.schemaVersion = "1.0.0";
}

@JsonProperty("maven")
Expand All @@ -149,6 +191,10 @@ public List<NoManifest> getOpenManifests() {
return noManifests;
}

public String getSchemaVersion() {
return schemaVersion;
}

public void addManifest(MavenManifest manifest) {
mavenManifests.add(manifest);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,11 @@
import org.eclipse.aether.RepositorySystem;
import org.eclipse.aether.repository.LocalRepository;
import org.jboss.galleon.util.HashUtils;
import org.jboss.logging.Logger;
import org.wildfly.channel.Channel;
import org.wildfly.channel.ChannelManifest;
import org.wildfly.channel.ChannelManifestCoordinate;
import org.wildfly.channel.ChannelManifestMapper;
import org.wildfly.channel.Repository;
import org.wildfly.channel.maven.VersionResolverFactory;
import org.wildfly.channel.spi.MavenVersionsResolver;
Expand All @@ -48,6 +51,7 @@
* for open manifests it's list of repositories + strategy.
*/
public class ManifestVersionResolver {
private static final Logger LOG = Logger.getLogger(ManifestVersionResolver.class.getName());

private final VersionResolverFactory resolverFactory;

Expand Down Expand Up @@ -89,19 +93,53 @@ public ManifestVersionRecord getCurrentVersions(List<Channel> channels) throws I
} else if (manifestCoordinate.getUrl() != null) {
final String content = read(manifestCoordinate.getUrl());
final String hashCode = HashUtils.hash(content);
manifestVersionRecord.addManifest(new ManifestVersionRecord.UrlManifest(manifestCoordinate.getUrl().toExternalForm(), hashCode));
final ChannelManifest manifest = ChannelManifestMapper.from(manifestCoordinate.getUrl());
manifestVersionRecord.addManifest(new ManifestVersionRecord.UrlManifest(manifestCoordinate.getUrl().toExternalForm(), hashCode, manifest.getName()));
} else if (manifestCoordinate.getVersion() != null) {
manifestVersionRecord.addManifest(new ManifestVersionRecord.MavenManifest(manifestCoordinate.getGroupId(), manifestCoordinate.getArtifactId(), manifestCoordinate.getVersion()));
final String description = getManifestDescription(manifestCoordinate, resolverFactory.create(channel.getRepositories()));
manifestVersionRecord.addManifest(new ManifestVersionRecord.MavenManifest(
manifestCoordinate.getGroupId(),
manifestCoordinate.getArtifactId(),
manifestCoordinate.getVersion(),
description));
} else {
final MavenVersionsResolver mavenVersionsResolver = resolverFactory.create(channel.getRepositories());
final Optional<String> latestVersion = VersionMatcher.getLatestVersion(mavenVersionsResolver.getAllVersions(manifestCoordinate.getGroupId(), manifestCoordinate.getArtifactId(),
manifestCoordinate.getExtension(), manifestCoordinate.getClassifier()));
manifestVersionRecord.addManifest(new ManifestVersionRecord.MavenManifest(manifestCoordinate.getGroupId(), manifestCoordinate.getArtifactId(), latestVersion.get()));
if (latestVersion.isPresent()) {
final String description = getManifestDescription(new ChannelManifestCoordinate(
manifestCoordinate.getGroupId(), manifestCoordinate.getArtifactId(), latestVersion.get()
), mavenVersionsResolver);
manifestVersionRecord.addManifest(new ManifestVersionRecord.MavenManifest(
manifestCoordinate.getGroupId(),
manifestCoordinate.getArtifactId(),
latestVersion.get(),
description));
} else {
LOG.warn("Unable to determine version of manifest used: " + manifestCoordinate);
manifestVersionRecord.addManifest(new ManifestVersionRecord.MavenManifest(
manifestCoordinate.getGroupId(),
manifestCoordinate.getArtifactId(),
"",
null));
}
}
}
return manifestVersionRecord;
}

private String getManifestDescription(ChannelManifestCoordinate manifestCoordinate, MavenVersionsResolver mavenVersionsResolver) {
final List<URL> urls = mavenVersionsResolver.resolveChannelMetadata(List.of(manifestCoordinate));
final String description;
if (!urls.isEmpty()) {
final ChannelManifest manifest = ChannelManifestMapper.from(urls.get(0));
description = manifest.getName();
} else {
description = null;
}
return description;
}

private String read(URL url) throws IOException {
try(InputStream inputStream = url.openStream();
OutputStream outputStream = new ByteArrayOutputStream()) {
Expand Down
Loading

0 comments on commit 5325eae

Please sign in to comment.