com.gs.obevo.cmdline.DeployerArgs Maven / Gradle / Ivy
/**
* Copyright 2017 Goldman Sachs.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package com.gs.obevo.cmdline;
import java.io.File;
import java.util.Arrays;
import com.gs.obevo.util.inputreader.Credential;
import com.sampullara.cli.Argument;
import org.eclipse.collections.api.list.primitive.ImmutableBooleanList;
import org.eclipse.collections.impl.block.factory.StringFunctions;
import org.eclipse.collections.impl.block.factory.primitive.BooleanPredicates;
import org.eclipse.collections.impl.factory.primitive.BooleanLists;
import org.eclipse.collections.impl.set.mutable.UnifiedSet;
public class DeployerArgs {
private String[] envNames;
private String[] actions;
private boolean setupEnvInfraOnly = false;
private boolean cleanFirst = false;
private boolean cleanOnly = false;
private boolean noPrompt = false;
private boolean useBaseline = false;
private String includeFile = null;
private String password;
private boolean useKerberosAuth;
private String keytabPath;
private String sourcePath;
private File workDir;
private String deployUserId;
private boolean performInitOnly = false;
private boolean preview = false;
private boolean rollback = false;
private boolean onboardingMode;
private String changeCriteria;
private String[] changesets;
private boolean allChangesets;
private String productVersion;
/**
* No longer used.
*
* @deprecated see {@link #strictSetupEnvInfra}
*/
@Deprecated
private boolean lenientSetupEnvInfra = false;
private boolean strictSetupEnvInfra = false;
private Boolean forceEnvSetup;
@Argument(value = "env", required = false)
public void setEnvNames(String[] envNames) {
this.envNames = envNames;
}
public String[] getEnvNames() {
return this.envNames;
}
public String[] getActions() {
return actions;
}
@Argument(value = "action", required = false,
description = "3 possible arguments as a comma-separated list - deploy, clean (wipes all db objects), and setup (DEPRECATED). Defaults to deploy."
)
public void setActions(String[] actions) {
this.actions = actions;
}
public boolean isSetupEnvInfraOnly() {
return this.setupEnvInfraOnly;
}
@Argument(value = "setupEnvInfraOnly", description = "DEPRECATED")
public void setSetupEnvInfraOnly(boolean setupEnvInfraOnly) {
this.setupEnvInfraOnly = setupEnvInfraOnly;
}
public boolean isCleanFirst() {
return this.cleanFirst;
}
@Argument(
value = "cleanFirst",
description = "DEPRECATED - use the -action argument. Indicates if the environments should be wiped prior to development. Only allowed for certain environments, per the metadata setup")
public void setCleanFirst(boolean cleanFirst) {
this.cleanFirst = cleanFirst;
}
public boolean isCleanOnly() {
return this.cleanOnly;
}
@Argument(
value = "cleanOnly",
description = "DEPRECATED - use the -action argument. Indicates if the environments should be wiped prior to development and nothing else done. " +
"Only allowed for certain environments, per the metadata setup")
public void setCleanOnly(boolean cleanOnly) {
this.cleanOnly = cleanOnly;
}
public boolean isUseBaseline() {
return this.useBaseline;
}
public String getIncludeFile() {
return this.includeFile;
}
@Argument(value = "useBaseline", description = "If set, then will use the baseline files for db table deployments. Only to be used in a test schema")
public void setUseBaseline(boolean useBaseline) {
this.useBaseline = useBaseline;
}
@Argument(value = "includeFile", description = "If set, then will use the include files for db objects deployments.")
public void setIncludeFile(String includeFile) {
this.includeFile = includeFile;
}
public boolean isNoPrompt() {
return this.noPrompt;
}
@Argument(value = "noPrompt", description = "If set, then the deployment will proceed without user prompting")
public void setNoPrompt(boolean noPrompt) {
this.noPrompt = noPrompt;
}
public String getPassword() {
return this.password;
}
@Argument(value = "password", required = false, description = "kerberos password for the deployUserId")
public void setPassword(String password) {
this.password = password;
}
public boolean isUseKerberosAuth() {
return this.useKerberosAuth;
}
@Argument(value = "useKerberosAuth", required = false, description = "true if an existing kerberos ticket should be used for authentication; defaults to false (i.e. needing a password)")
public void setUseKerberosAuth(boolean useKerberosAuth) {
this.useKerberosAuth = useKerberosAuth;
}
public String getKeytabPath() {
return keytabPath;
}
@Argument(value = "keytabPath", required = false, description = "path to the keytab to authenticate it; only supported in Sybase IQ ODBC drivers currently")
public void setKeytabPath(String keytabPath) {
this.keytabPath = keytabPath;
}
public String getSourcePath() {
return this.sourcePath;
}
@Argument(value = "sourcePath", required = false)
public void setSourcePath(String sourcePath) {
this.sourcePath = sourcePath;
}
public Credential getCredential() {
ImmutableBooleanList chosenCredentialModes = BooleanLists.immutable.with(password != null, useKerberosAuth, keytabPath != null)
.select(BooleanPredicates.isTrue());
if (deployUserId == null) {
if (password == null) {
return null;
} else {
throw new IllegalArgumentException("Cannot provide password without deployUserId; provide both or neither (neither will cause a prompt)");
}
} else if (chosenCredentialModes.size() > 2) {
throw new IllegalArgumentException("Cannot provide more than one of password or useKerberosAuth flag or keytabPath; pick one");
} else if (chosenCredentialModes.size() == 0) {
throw new IllegalArgumentException("Cannot provide deployUserId without password or useKerberosAuth flag or keytabPath");
} else if (password != null) {
return new Credential(deployUserId, password);
} else if (keytabPath != null) {
Credential credential = new Credential();
credential.setUsername(deployUserId);
credential.setKeytabPath(keytabPath);
return credential;
} else {
Credential credential = new Credential();
credential.setUsername(deployUserId);
credential.setUseKerberosAuth(true);
return credential;
}
}
public String getDeployUserId() {
return this.deployUserId;
}
@Argument(value = "deployUserId", required = false, description = "Kerberos of deployer (for auditing)")
public void setDeployUserId(String deployUserId) {
this.deployUserId = deployUserId;
}
public File getWorkDir() {
return this.workDir;
}
@Argument(value = "workDir", required = false, description = "only used for unit tests or special cases")
public void setWorkDir(File workDir) {
this.workDir = workDir;
}
public void validate() {
}
public boolean isPerformInitOnly() {
return this.performInitOnly;
}
@Argument(value = "performInitOnly", required = false, description = "performInitOnly")
public void setPerformInitOnly(boolean performInitOnly) {
this.performInitOnly = performInitOnly;
}
public boolean isPreview() {
return this.preview;
}
@Argument(value = "preview", required = false, description = "Will only preview the changes and not proceed with the actual deployment (only for deployers that support it, e.g. Database)")
public void setPreview(boolean preview) {
this.preview = preview;
}
public boolean isRollback() {
return this.rollback;
}
@Argument(value = "rollback", required = false, description = "Will carry out the deployment in rollback mode (assumes that you are already pointing to the old location)")
public void setRollback(boolean rollback) {
this.rollback = rollback;
}
private boolean isActionContains(String command) {
return this.actions != null && UnifiedSet.newSetWith(this.actions).collect(StringFunctions.toLowerCase()).contains(command);
}
public boolean shouldExecuteClean() {
return this.cleanFirst
|| this.cleanOnly
|| isActionContains("clean");
}
public boolean shouldExecuteDeploy() {
return (isActionContains("deploy") || actions == null)
&& !(this.setupEnvInfraOnly || this.cleanOnly);
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("DeployerArgs [");
if (envNames != null) {
builder.append("envNames=").append(Arrays.toString(envNames)).append(", ");
}
if (actions != null) {
builder.append("actions=").append(Arrays.toString(actions)).append(", ");
}
builder.append(", setupEnvInfraOnly=").append(setupEnvInfraOnly)
.append(", cleanFirst=").append(cleanFirst).append(", cleanOnly=").append(cleanOnly)
.append(", noPrompt=").append(noPrompt).append(", useBaseline=").append(useBaseline)
.append(", onboardingMode=").append(onboardingMode)
.append(", ");
if (includeFile != null) {
builder.append("includeFile=").append(includeFile).append(", ");
}
builder.append("useKerberosAuth=").append(useKerberosAuth).append(", ");
if (sourcePath != null) {
builder.append("sourcePath=").append(sourcePath).append(", ");
}
if (workDir != null) {
builder.append("workDir=").append(workDir).append(", ");
}
if (deployUserId != null) {
builder.append("deployUserId=").append(deployUserId).append(", ");
}
builder.append("performInitOnly=").append(performInitOnly).append(", preview=").append(preview)
.append(", rollback=").append(rollback).append(", ");
builder.append("]");
return builder.toString();
}
public boolean isOnboardingMode() {
return onboardingMode;
}
@Argument(value = "onboardingMode", description = "Enable the mode to help when initially onboarding an existing reverse-engineered schema")
public void setOnboardingMode(boolean onboardingMode) {
this.onboardingMode = onboardingMode;
}
public String getChangeCriteria() {
return changeCriteria;
}
@Argument(value = "changeCriteria", description = "Criteria string to only deploy a subset of changes; see documentation for more info")
public void setChangeCriteria(String changeCriteria) {
this.changeCriteria = changeCriteria;
}
public String[] getChangesets() {
return changesets;
}
@Argument(value = "changesets", description = "Changeset names to deploy; defaults to empty, which means to only deploy the default changeset")
public void setChangesets(String[] changesets) {
this.changesets = changesets;
}
public boolean isAllChangesets() {
return allChangesets;
}
@Argument(value = "allChangesets", description = "Whether to force deployments of all changesets (both default and named changesets); defaults to false (only to deploy the default changeset)")
public void setAllChangesets(boolean allChangesets) {
this.allChangesets = allChangesets;
}
public String getProductVersion() {
return productVersion;
}
@Argument(value = "productVersion", description = "(Optional, defaults to null) The version number that the user assigns to a product. Meant to help w/ audit trail and special features like rollback detection.")
public void setProductVersion(String productVersion) {
this.productVersion = productVersion;
}
/**
* No longer used, as this is lenient by default.
*
* @deprecated See {@link #isStrictSetupEnvInfra()}
*/
@Deprecated
public boolean isLenientSetupEnvInfra() {
return lenientSetupEnvInfra;
}
/**
* No longer used, as this is lenient by default.
*
* @deprecated See {@link #isStrictSetupEnvInfra()}
*/
@Argument(value = "lenientSetupEnvInfra", description = "Deprecated - the setupEnvironmentInfra command is now lenient by default. See the -strictSetupEnvInfra option instead if you'd like it strict")
@Deprecated
public void setLenientSetupEnvInfra(boolean lenientSetupEnvInfra) {
this.lenientSetupEnvInfra = lenientSetupEnvInfra;
}
public boolean isStrictSetupEnvInfra() {
return strictSetupEnvInfra;
}
@Argument(value = "strictSetupEnvInfra", description = "Include this option to fail in case of missing groups/users; default is to log a warning")
public void setStrictSetupEnvInfra(boolean strictSetupEnvInfra) {
this.strictSetupEnvInfra = strictSetupEnvInfra;
}
public Boolean getForceEnvSetup() {
return forceEnvSetup;
}
@Argument(value = "forceEnvSetup", description = "Whether to create schema objects prior to object deployment; default is to go w/ the platform-specific behavior")
public void setForceEnvSetup(Boolean forceEnvSetup) {
this.forceEnvSetup = forceEnvSetup;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy