/* * 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 2016 ForgeRock AS. */ package org.forgerock.opendj.server.embedded; /** Parameters for replication operations on a directory server. */ public final class ReplicationParameters { private String baseDn; private Integer replicationPortSource; private Integer replicationPortDestination; private ConnectionParameters connParamsForDestination; private ReplicationParameters() { // prefer usage of static method for creation } /** * Creates a builder for the replication parameters. * * @return a builder */ public static ReplicationParameters replicationParams() { return new ReplicationParameters(); } /** * Generates the command-line arguments for configuring replication, from the parameters. * * @return command-line arguments */ String[] toCommandLineArgumentsConfiguration(String configurationFile, ConnectionParameters connParams) { return new String[] { "enable", "--no-prompt", "--configFile", configurationFile, "--host1", connParams.getHostName(), "--port1", s(connParams.getAdminPort()), "--bindDN1", connParams.getBindDn(), "--bindPassword1", connParams.getBindPassword(), "--replicationPort1", s(replicationPortSource), "--host2", connParamsForDestination.getHostName(), "--port2", s(connParamsForDestination.getAdminPort()), "--bindDN2", connParamsForDestination.getBindDn(), "--bindPassword2", connParamsForDestination.getBindPassword(), "--replicationPort2", s(replicationPortDestination), "--adminUID", connParams.getAdminUid(), "--adminPassword", connParams.getAdminPassword(), "--baseDN", baseDn, "--trustAll", "--noPropertiesFile" }; } /** * Generates the command-line arguments for initializing replication, from the parameters. * * @return command-line arguments */ String[] toCommandLineArgumentsInitialize(String configurationFile, ConnectionParameters connParams) { return new String[] { "initialize", "--no-prompt", "--configFile", configurationFile, "--hostSource", connParams.getHostName(), "--portSource", s(connParams.getAdminPort()), "--hostDestination", connParamsForDestination.getHostName(), "--portDestination", s(connParamsForDestination.getAdminPort()), "--adminUID", connParams.getAdminUid(), "--adminPassword", connParams.getAdminPassword(), "--baseDN", baseDn, "--trustAll", "--noPropertiesFile" }; } /** * Generates the command-line arguments for output of the replication status, from the parameters. * * @return command-line arguments */ String[] toCommandLineArgumentsStatus(String configurationFile, ConnectionParameters connParams) { return new String[] { "status", "--no-prompt", "--configFile", configurationFile, "--hostname", connParams.getHostName(), "--port", s(connParams.getAdminPort()), "--adminUID", connParams.getAdminUid(), "--adminPassword", connParams.getAdminPassword(), "--script-friendly", "--noPropertiesFile" }; } @Override public String toString() { return "ReplicationParameters [baseDn=" + baseDn + ", source replication port=" + replicationPortSource + ", destination host name=" + getHostNameDestination() + ", destination replication port=" + replicationPortDestination + ", destination admin port=" + getAdminPortDestination() + "]"; } int getReplicationPortSource() { return replicationPortSource; } int getReplicationPortDestination() { return replicationPortDestination; } String getHostNameDestination() { return connParamsForDestination.getHostName(); } int getAdminPortDestination() { return connParamsForDestination.getAdminPort(); } /** Convert an integer to a String. */ private String s(Integer val) { return String.valueOf(val); } /** * Sets the base Dn of the data to be replicated. * * @param baseDn * the base Dn * @return this builder */ public ReplicationParameters baseDn(String baseDn) { this.baseDn = baseDn; return this; } /** * Sets the replication port of the first server (source) whose contents will be replicated. *

* The source server should correspond to the embedded server on which the replication operation is * applied. * * @param port * the replication port * @return this builder */ public ReplicationParameters replicationPortSource(int port) { this.replicationPortSource = port; return this; } /** * Sets the replication port of the second server (destination) whose contents will be replicated. * * @param port * the replication port * @return this builder */ public ReplicationParameters replicationPortDestination(int port) { this.replicationPortDestination = port; return this; } /** * Sets the connection parameters of the second server (destination) whose contents will be replicated. * * @param destinationParams * The connection parameters for destination server * @return this builder */ public ReplicationParameters connectionParamsForDestination(ConnectionParameters destinationParams) { this.connParamsForDestination = destinationParams; return this; } }