/*
|
* 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;
|
|
import java.util.ArrayList;
|
import java.util.List;
|
|
/**
|
* Parameters to upgrade a Directory Server.
|
*/
|
public final class UpgradeParameters
|
{
|
private boolean ignoreErrors;
|
|
private UpgradeParameters()
|
{
|
// private constructor to force usage of the associated Builder
|
}
|
|
/**
|
* Generates command-line arguments from the parameters.
|
*
|
* @return command-line arguments
|
*/
|
String[] toCommandLineArguments(String configurationFile)
|
{
|
List<String> args = new ArrayList<>(6);
|
args.add("--acceptLicense");
|
args.add("--no-prompt");
|
args.add("--force");
|
args.add("--configFile");
|
args.add(configurationFile);
|
if (ignoreErrors) {
|
args.add("--ignoreErrors");
|
}
|
return args.toArray(new String[args.size()]);
|
}
|
|
/**
|
* Builder for the UpgradeParameters class.
|
*/
|
public static final class Builder
|
{
|
private UpgradeParameters params;
|
|
private Builder()
|
{
|
params = new UpgradeParameters();
|
}
|
|
/**
|
* Starts construction of the upgrade parameters.
|
*
|
* @return this builder
|
*/
|
public static Builder upgradeParams()
|
{
|
return new Builder();
|
}
|
|
/**
|
* Returns the fully initialized parameters.
|
*
|
* @return the parameters
|
*/
|
public UpgradeParameters toParams()
|
{
|
UpgradeParameters p = params;
|
this.params = new UpgradeParameters();
|
return p;
|
}
|
|
/**
|
* Indicates whether errors should be ignored during the upgrade.
|
* <p>
|
* This option should be used with caution and may be useful in automated deployments where
|
* potential errors are known in advance and resolved after the upgrade has completed
|
*
|
* @param ignore
|
* indicates whether errors should be ignored
|
* @return this builder
|
*/
|
public Builder isIgnoreErrors(boolean ignore)
|
{
|
params.ignoreErrors = ignore;
|
return this;
|
}
|
}
|
}
|