/* * The contents of this file are subject to the terms of the Common Development and * Distribution License (the License). You may not use this file except in compliance with the * License. * * You can obtain a copy of the License at legal/CDDLv1.0.txt. See the License for the * specific language governing permission and limitations under the License. * * When distributing Covered Software, include this CDDL Header Notice in each file and include * the License file at legal/CDDLv1.0.txt. If applicable, add the following below the CDDL * Header, with the fields enclosed by brackets [] replaced by your own identifying * information: "Portions Copyright [year] [name of copyright owner]". * * Copyright 2008 Sun Microsystems, Inc. * Portions Copyright 2015 ForgeRock AS. */ package org.opends.admin.ads; import java.util.HashSet; import java.util.Set; /** * The object of this class represent a topology of replicas across servers that * have the same suffix DN. If there is more than one replica on the suffix, the * contents of the replicas are replicated. */ public class SuffixDescriptor { private String suffixDN; private final Set replicas = new HashSet<>(); /** * Returns the DN associated with this suffix descriptor. * * @return the DN associated with this suffix descriptor. */ public String getDN() { return suffixDN; } /** * Sets the DN associated with this suffix descriptor. * * @param suffixDN * the DN associated with this suffix descriptor. */ public void setDN(String suffixDN) { this.suffixDN = suffixDN; } /** * Returns the replicas associated with this SuffixDescriptor. * * @return a Set containing the replicas associated with this * SuffixDescriptor. */ public Set getReplicas() { return new HashSet<>(replicas); } /** * Sets the replicas associated with this SuffixDescriptor. * * @param replicas * a Set containing the replicas associated with this * SuffixDescriptor. */ public void setReplicas(Set replicas) { this.replicas.clear(); this.replicas.addAll(replicas); } /** * Returns the Set of Replication servers for the whole suffix topology. The * servers are provided in their String representation. * * @return the Set of Replication servers for the whole suffix topology. */ public Set getReplicationServers() { Set replicationServers = new HashSet<>(); for (ReplicaDescriptor replica : getReplicas()) { replicationServers.addAll(replica.getReplicationServers()); } return replicationServers; } @Override public int hashCode() { return getId().hashCode(); } /** * Returns an Id that is unique for this suffix. * * @return an Id that is unique for this suffix. */ public String getId() { StringBuilder buf = new StringBuilder(); buf.append(getDN()); for (ReplicaDescriptor replica : getReplicas()) { buf.append("-").append(replica.getServer().getId()); } return buf.toString(); } }