All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.discovery.util.ApplicationFunctions Maven / Gradle / Ivy

There is a newer version: 2.0.4
Show newest version
package com.netflix.discovery.util;

import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.netflix.appinfo.InstanceInfo;
import com.netflix.discovery.shared.Application;
import com.netflix.discovery.shared.Applications;

/**
 * Collection of functions operating on {@link Applications} and {@link Application} data
 * structures.
 *
 * @author Tomasz Bak
 * @deprecated Use instead {@link EurekaEntityFunctions}
 */
public final class ApplicationFunctions {

    private ApplicationFunctions() {
    }

    public static Map toApplicationMap(List instances) {
        Map applicationMap = new HashMap();
        for (InstanceInfo instance : instances) {
            String appName = instance.getAppName();
            Application application = applicationMap.get(appName);
            if (application == null) {
                applicationMap.put(appName, application = new Application(appName));
            }
            application.addInstance(instance);
        }
        return applicationMap;
    }

    public static Applications toApplications(Map applicationMap) {
        Applications applications = new Applications();
        for (Application application : applicationMap.values()) {
            applications.addApplication(application);
        }
        return updateMeta(applications);
    }

    public static Set applicationNames(Applications applications) {
        Set names = new HashSet();
        for (Application application : applications.getRegisteredApplications()) {
            names.add(application.getName());
        }
        return names;
    }

    public static Application copyOf(Application application) {
        Application copy = new Application(application.getName());
        for (InstanceInfo instance : application.getInstances()) {
            copy.addInstance(instance);
        }
        return copy;
    }

    public static Application merge(Application first, Application second) {
        if (!first.getName().equals(second.getName())) {
            throw new IllegalArgumentException("Cannot merge applications with different names");
        }
        Application merged = copyOf(first);
        for (InstanceInfo instance : second.getInstances()) {
            switch (instance.getActionType()) {
                case ADDED:
                case MODIFIED:
                    merged.addInstance(instance);
                    break;
                case DELETED:
                    merged.removeInstance(instance);
            }
        }
        return merged;
    }

    public static Applications merge(Applications first, Applications second) {
        Set firstNames = applicationNames(first);
        Set secondNames = applicationNames(second);
        Set allNames = new HashSet(firstNames);
        allNames.addAll(secondNames);

        Applications merged = new Applications();
        for (String appName : allNames) {
            if (firstNames.contains(appName)) {
                if (secondNames.contains(appName)) {
                    merged.addApplication(merge(first.getRegisteredApplications(appName), second.getRegisteredApplications(appName)));
                } else {
                    merged.addApplication(copyOf(first.getRegisteredApplications(appName)));
                }
            } else {
                merged.addApplication(copyOf(second.getRegisteredApplications(appName)));
            }
        }
        return updateMeta(merged);
    }

    public static Applications updateMeta(Applications applications) {
        applications.setVersion(1L);
        applications.setAppsHashCode(applications.getReconcileHashCode());
        return applications;
    }

    public static int countInstances(Applications applications) {
        int count = 0;
        for(Application application: applications.getRegisteredApplications()) {
            count += application.getInstances().size();
        }
        return count;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy