aboutsummaryrefslogtreecommitdiffstats
path: root/controller-api
diff options
context:
space:
mode:
authorjonmv <venstad@gmail.com>2022-11-03 12:29:06 +0100
committerjonmv <venstad@gmail.com>2022-11-03 12:29:06 +0100
commit2072d62e624e5684a56c0ed6af71f425c23af90a (patch)
tree4fa574fd9fe96a011b36f12b3a48e3e63aecb1a3 /controller-api
parent2b0c27060304256a26f5def0ecfa5265c2cde306 (diff)
Add option to get application package streams from ApplicationStore
Diffstat (limited to 'controller-api')
-rw-r--r--controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationStore.java25
1 files changed, 23 insertions, 2 deletions
diff --git a/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationStore.java b/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationStore.java
index c4db0de539e..71ec07bc2e6 100644
--- a/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationStore.java
+++ b/controller-api/src/main/java/com/yahoo/vespa/hosted/controller/api/integration/deployment/ApplicationStore.java
@@ -5,6 +5,9 @@ import com.yahoo.config.provision.ApplicationName;
import com.yahoo.config.provision.TenantName;
import com.yahoo.vespa.hosted.controller.api.identifiers.DeploymentId;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.UncheckedIOException;
import java.time.Instant;
import java.util.Optional;
@@ -17,7 +20,16 @@ import java.util.Optional;
public interface ApplicationStore {
/** Returns the application package of the given revision. */
- byte[] get(DeploymentId deploymentId, RevisionId revisionId);
+ default byte[] get(DeploymentId deploymentId, RevisionId revisionId) {
+ try (InputStream stream = stream(deploymentId, revisionId)) {
+ return stream.readAllBytes();
+ }
+ catch (IOException e) {
+ throw new UncheckedIOException(e);
+ }
+ }
+
+ InputStream stream(DeploymentId deploymentId, RevisionId revisionId);
/** Returns the application package diff, compared to the previous build, for the given tenant, application and build number */
Optional<byte[]> getDiff(TenantName tenantName, ApplicationName applicationName, long buildNumber);
@@ -43,7 +55,16 @@ public interface ApplicationStore {
void removeAll(TenantName tenant, ApplicationName application);
/** Returns the tester application package of the given revision. Does NOT contain the services.xml. */
- byte[] getTester(TenantName tenant, ApplicationName application, RevisionId revision);
+ default byte[] getTester(TenantName tenant, ApplicationName application, RevisionId revision) {
+ try (InputStream stream = streamTester(tenant, application, revision)) {
+ return stream.readAllBytes();
+ }
+ catch (IOException e) {
+ throw new UncheckedIOException(e);
+ }
+ }
+
+ InputStream streamTester(TenantName tenantName, ApplicationName applicationName, RevisionId revision);
/** Returns the application package diff, compared to the previous build, for the given deployment and build number */
Optional<byte[]> getDevDiff(DeploymentId deploymentId, long buildNumber);