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

org.jgroups.protocols.relay.SiteStatus Maven / Gradle / Ivy

package org.jgroups.protocols.relay;

import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

/**
 * Maintains the status of sites (up, down, undefined). This weeds out duplicate up or down notifications
 * @author Bela Ban
 * @since  5.2.17
 */
public class SiteStatus {
    public enum Status {up,down};
    protected final Map sites=new HashMap<>();

    /**
     * Adds a set of sites to the cache. Returns a set of sites for which notifications should be emitted. For each
     * site S, the following happens:
     * 
     *  - S is not present: add a new entry with the given status for S and add S to the return value
     *  - S is present: if S != status: change the status and add S to the return value, else no-op
     * 
* @param sites * @param status * @return */ public synchronized Set add(Set sites, Status status) { Set retval=new HashSet<>(); for(String site: sites) { Status s=this.sites.get(site); if(s == null) { this.sites.put(site, status); retval.add(site); } else { if(s != status) { this.sites.put(site, status); retval.add(site); } } } return retval; } public synchronized Status get(String site) { return this.sites.get(site); } public synchronized SiteStatus clear() { sites.clear(); return this; } public String toString() { return sites.entrySet().stream() .map(e -> String.format("%s: %s", e.getKey(), e.getValue())).collect(Collectors.joining("\n")); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy