summaryrefslogtreecommitdiffstats
path: root/config-model-api
diff options
context:
space:
mode:
authorHåkon Hallingstad <hakon@oath.com>2017-09-25 14:11:21 +0200
committerHåkon Hallingstad <hakon@oath.com>2017-09-25 14:11:21 +0200
commit112e023607f8a20a006dadfa07f29b36c3040860 (patch)
tree9a28b4f977197bb2479d2122331c761b3e9a9421 /config-model-api
parented516f90c03d2f5d4438c1c744b7aeea7edb6cab (diff)
Move SuperModel to config-model-api
This avoids duplication of datastructures in service monitor
Diffstat (limited to 'config-model-api')
-rw-r--r--config-model-api/src/main/java/com/yahoo/config/model/api/SuperModel.java91
-rw-r--r--config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelListener.java4
-rw-r--r--config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelProvider.java11
3 files changed, 101 insertions, 5 deletions
diff --git a/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModel.java b/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModel.java
new file mode 100644
index 00000000000..d03824120d8
--- /dev/null
+++ b/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModel.java
@@ -0,0 +1,91 @@
+// Copyright 2017 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
+package com.yahoo.config.model.api;
+
+import com.yahoo.config.provision.ApplicationId;
+import com.yahoo.config.provision.TenantName;
+
+import java.util.Collections;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Optional;
+import java.util.stream.Collectors;
+
+public class SuperModel {
+ private final Map<TenantName, Map<ApplicationId, ApplicationInfo>> models;
+
+ public SuperModel() {
+ this.models = Collections.emptyMap();
+ }
+
+ public SuperModel(Map<TenantName, Map<ApplicationId, ApplicationInfo>> models) {
+ this.models = models;
+ }
+
+ /**
+ * Do NOT mutate the returned map.
+ * TODO: Make the returned map immutable (and type to Map&lt;ApplicationId, ApplicationInfo&gt;)
+ */
+ public Map<TenantName, Map<ApplicationId, ApplicationInfo>> getAllModels() {
+ return models;
+ }
+
+ public List<ApplicationInfo> getAllApplicationInfos() {
+ return models.values().stream().flatMap(entry -> entry.values().stream()).collect(Collectors.toList());
+ }
+
+ public Optional<ApplicationInfo> getApplicationInfo(ApplicationId applicationId) {
+ Map<ApplicationId, ApplicationInfo> tenantInfo = models.get(applicationId.tenant());
+ if (tenantInfo == null) {
+ return Optional.empty();
+ }
+
+ ApplicationInfo applicationInfo = tenantInfo.get(applicationId);
+ if (applicationInfo == null) {
+ return Optional.empty();
+ }
+
+ return Optional.of(applicationInfo);
+ }
+
+ public SuperModel cloneAndSetApplication(ApplicationInfo application) {
+ TenantName tenant = application.getApplicationId().tenant();
+ Map<TenantName, Map<ApplicationId, ApplicationInfo>> newModels = cloneModels(models);
+ if (!newModels.containsKey(tenant)) {
+ // New application has been activated
+ newModels.put(tenant, new LinkedHashMap<>());
+ } else {
+ // Application has been redeployed
+ }
+
+ newModels.get(tenant).put(application.getApplicationId(), application);
+
+ return new SuperModel(newModels);
+ }
+
+ public SuperModel cloneAndRemoveApplication(ApplicationId applicationId) {
+ Map<TenantName, Map<ApplicationId, ApplicationInfo>> newModels = cloneModels(models);
+ if (newModels.containsKey(applicationId.tenant())) {
+ newModels.get(applicationId.tenant()).remove(applicationId);
+ if (newModels.get(applicationId.tenant()).isEmpty()) {
+ newModels.remove(applicationId.tenant());
+ }
+ }
+
+ return new SuperModel(newModels);
+ }
+
+ private static Map<TenantName, Map<ApplicationId, ApplicationInfo>> cloneModels(
+ Map<TenantName, Map<ApplicationId, ApplicationInfo>> models) {
+ Map<TenantName, Map<ApplicationId, ApplicationInfo>> newModels = new LinkedHashMap<>();
+ for (Map.Entry<TenantName, Map<ApplicationId, ApplicationInfo>> entry : models.entrySet()) {
+ Map<ApplicationId, ApplicationInfo> appMap = new LinkedHashMap<>();
+ newModels.put(entry.getKey(), appMap);
+ for (Map.Entry<ApplicationId, ApplicationInfo> appEntry : entry.getValue().entrySet()) {
+ appMap.put(appEntry.getKey(), appEntry.getValue());
+ }
+ }
+
+ return newModels;
+ }
+}
diff --git a/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelListener.java b/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelListener.java
index 16580c9e9f6..043e23902b2 100644
--- a/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelListener.java
+++ b/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelListener.java
@@ -11,10 +11,10 @@ public interface SuperModelListener {
* Application has been activated: Either deployed the first time,
* internally redeployed, or externally triggered redeploy.
*/
- void applicationActivated(ApplicationInfo application);
+ void applicationActivated(SuperModel superModel, ApplicationId id);
/**
* Application has been removed.
*/
- void applicationRemoved(ApplicationId id);
+ void applicationRemoved(SuperModel superModel, ApplicationId id);
}
diff --git a/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelProvider.java b/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelProvider.java
index 42437b20b83..4c7f15143ec 100644
--- a/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelProvider.java
+++ b/config-model-api/src/main/java/com/yahoo/config/model/api/SuperModelProvider.java
@@ -1,13 +1,18 @@
// Copyright 2017 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.config.model.api;
-import java.util.List;
+import com.yahoo.config.provision.Zone;
public interface SuperModelProvider {
+ SuperModel getSuperModel();
+
/**
- * Returns all applications in the SuperModel. All changes to the SuperModel
+ * Returns the current SuperModel. All changes to the SuperModel
* following that snapshot will be published to the listener. Warning: The listener
* methods may have been invoked before (or concurrently with) this method returning.
*/
- List<ApplicationInfo> snapshot(SuperModelListener listener);
+ SuperModel snapshot(SuperModelListener listener);
+
+ // TODO: Remove - clients of SuperModel should get zone from elsewhere.
+ Zone getZone();
}