/* * 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.opends.server.util.embedded; /** * Parameters for replication operations on a directory server. */ public final class ReplicationParameters { private String baseDn; private Integer replicationPort1; private Integer replicationPort2; private ConnectionParameters connParamsForHost2; private ReplicationParameters() { // private constructor to force usage of the associated Builder } /** * Generates the command-line arguments for enabling replication, from the parameters. * * @return command-line arguments */ String[] toCommandLineArgumentsEnable(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(replicationPort1), "--host2", connParamsForHost2.getHostname(), "--port2", s(connParamsForHost2.getAdminPort()), "--bindDN2", connParamsForHost2.getBindDn(), "--bindPassword2", connParamsForHost2.getBindPassword(), "--replicationPort2", s(replicationPort2), "--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", connParamsForHost2.getHostname(), "--portDestination", s(connParamsForHost2.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" }; } int getReplicationPort1() { return replicationPort1; } int getReplicationPort2() { return replicationPort2; } String getHostname2() { return connParamsForHost2.getHostname(); } int getAdminPort2() { return connParamsForHost2.getAdminPort(); } /** Convert an integer to a String. */ private String s(Integer val) { return String.valueOf(val); } /** * Builder for this class. */ public static final class Builder { private ReplicationParameters params; private Builder() { params = new ReplicationParameters(); } /** * Creates a builder for the replication parameters. * * @return a builder */ public static Builder replicationParams() { return new Builder(); } /** * Generates the parameters from this builder. *
* After this call, the builder is reset and can be used to generate other parameters. * * @return the replication parameters */ public ReplicationParameters toParams() { ReplicationParameters p = params; this.params = new ReplicationParameters(); return p; } /** * Sets the base Dn of the data to be replicated. * * @param baseDn * the base Dn * @return this builder */ public Builder baseDn(String baseDn) { params.baseDn = baseDn; return this; } /** * Sets the replication port of the first server whose contents will be replicated. *
* The first server should correspond to the embedded server on which the replication * operation is applied. * * @param port * the replication port * @return this builder */ public Builder replicationPort1(int port) { params.replicationPort1 = port; return this; } /** * Sets the replication port of the second server whose contents will be replicated. * * @param port * the replication port * @return this builder */ public Builder replicationPort2(int port) { params.replicationPort2 = port; return this; } /** * Sets the connection parameters of the second server whose contents will be replicated. * * @param host2Params * The connection parameters * @return this builder */ public Builder connectionParamsForHost2(ConnectionParameters.Builder host2Params) { params.connParamsForHost2 = host2Params.toParams(); return this; } } }