From 72e7534a3fdc7d4a535302ed77af37c7a0708086 Mon Sep 17 00:00:00 2001 From: Ola Aunrønning Date: Thu, 27 Jan 2022 10:20:58 +0100 Subject: Stores all deployed app versions. Stores app/bundle hashes --- .../integration/deployment/ApplicationVersion.java | 30 +++++++++++++++++----- 1 file changed, 24 insertions(+), 6 deletions(-) (limited to 'controller-api/src') diff --git a/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationVersion.java b/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationVersion.java index 3a863f21ca0..984035645ed 100644 --- a/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationVersion.java +++ b/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationVersion.java @@ -23,7 +23,8 @@ public class ApplicationVersion implements Comparable { */ public static final ApplicationVersion unknown = new ApplicationVersion(Optional.empty(), OptionalLong.empty(), Optional.empty(), Optional.empty(), Optional.empty(), - Optional.empty(), Optional.empty(), true); + Optional.empty(), Optional.empty(), true, + Optional.empty(), Optional.empty()); // This never changes and is only used to create a valid semantic version number, as required by application bundles private static final String majorVersion = "1.0"; @@ -36,11 +37,13 @@ public class ApplicationVersion implements Comparable { private final Optional sourceUrl; private final Optional commit; private final boolean deployedDirectly; + private final Optional applicationPackageHash; + private final Optional bundleHash; /** Public for serialisation only. */ public ApplicationVersion(Optional source, OptionalLong buildNumber, Optional authorEmail, Optional compileVersion, Optional buildTime, Optional sourceUrl, - Optional commit, boolean deployedDirectly) { + Optional commit, boolean deployedDirectly, Optional applicationPackageHash, Optional bundleHash) { if (buildNumber.isEmpty() && ( source.isPresent() || authorEmail.isPresent() || compileVersion.isPresent() || buildTime.isPresent() || sourceUrl.isPresent() || commit.isPresent())) throw new IllegalArgumentException("Build number must be present if any other attribute is"); @@ -65,26 +68,31 @@ public class ApplicationVersion implements Comparable { this.sourceUrl = Objects.requireNonNull(sourceUrl, "sourceUrl cannot be null"); this.commit = Objects.requireNonNull(commit, "commit cannot be null"); this.deployedDirectly = deployedDirectly; + this.applicationPackageHash = applicationPackageHash; + this.bundleHash = bundleHash; } /** Create an application package version from a completed build, without an author email */ public static ApplicationVersion from(SourceRevision source, long buildNumber) { return new ApplicationVersion(Optional.of(source), OptionalLong.of(buildNumber), Optional.empty(), - Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), false); + Optional.empty(), Optional.empty(), Optional.empty(), Optional.empty(), false, + Optional.empty(), Optional.empty()); } /** Creates a version from a completed build, an author email, and build meta data. */ public static ApplicationVersion from(SourceRevision source, long buildNumber, String authorEmail, Version compileVersion, Instant buildTime) { return new ApplicationVersion(Optional.of(source), OptionalLong.of(buildNumber), Optional.of(authorEmail), - Optional.of(compileVersion), Optional.of(buildTime), Optional.empty(), Optional.empty(), false); + Optional.of(compileVersion), Optional.of(buildTime), Optional.empty(), Optional.empty(), false, + Optional.empty(), Optional.empty()); } /** Creates a version from a completed build, an author email, and build meta data. */ public static ApplicationVersion from(Optional source, long buildNumber, Optional authorEmail, Optional compileVersion, Optional buildTime, - Optional sourceUrl, Optional commit, boolean deployedDirectly) { - return new ApplicationVersion(source, OptionalLong.of(buildNumber), authorEmail, compileVersion, buildTime, sourceUrl, commit, deployedDirectly); + Optional sourceUrl, Optional commit, boolean deployedDirectly, + Optional applicationPackageHash, Optional bundleHash ) { + return new ApplicationVersion(source, OptionalLong.of(buildNumber), authorEmail, compileVersion, buildTime, sourceUrl, commit, deployedDirectly, applicationPackageHash, bundleHash); } /** Returns a unique identifier for this version or "unknown" if version is not known */ @@ -115,6 +123,16 @@ public class ApplicationVersion implements Comparable { /** Returns the time this package was built, if known. */ public Optional buildTime() { return buildTime; } + /** Returns the hash of entire application package */ + public Optional applicationPackageHash() { + return applicationPackageHash; + } + + /** Returns the hash of app package except deployment/build-meta data */ + public Optional bundleHash() { + return bundleHash; + } + /** Returns the source URL for this application version. */ public Optional sourceUrl() { return sourceUrl.or(() -> source.map(source -> { -- cgit v1.2.3