/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2008 Sun Microsystems, Inc. */ 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 Set<ReplicaDescriptor> replicas = new HashSet<ReplicaDescriptor>(); /** * 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<ReplicaDescriptor> getReplicas() { Set<ReplicaDescriptor> copy = new HashSet<ReplicaDescriptor>(); copy.addAll(replicas); return copy; } /** * Sets the replicas associated with this SuffixDescriptor. * @param replicas a Set containing the replicas associated with this * SuffixDescriptor. */ public void setReplicas(Set<ReplicaDescriptor> 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<String> getReplicationServers() { Set<String> replicationServers = new HashSet<String>(); for (ReplicaDescriptor replica : getReplicas()) { replicationServers.addAll(replica.getReplicationServers()); } return replicationServers; } /** * {@inheritDoc} */ 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(); } }