java/sql-dk/src/info/globalcode/sql/dk/CLIOptions.java
author František Kučera <franta-hg@frantovo.cz>
Mon, 16 Dec 2013 15:29:02 +0100
branchv_0
changeset 15 bbd335b5410c
parent 14 189b1260b942
child 16 5b8fcd35d4d6
permissions -rw-r--r--
show info basics: list databases + test connection
franta-hg@1
     1
package info.globalcode.sql.dk;
franta-hg@1
     2
franta-hg@1
     3
import static info.globalcode.sql.dk.Functions.isNotEmpty;
franta-hg@15
     4
import static info.globalcode.sql.dk.Functions.isEmpty;
franta-hg@14
     5
import static info.globalcode.sql.dk.Functions.equalz;
franta-hg@1
     6
import java.util.ArrayList;
franta-hg@1
     7
import java.util.Collection;
franta-hg@14
     8
import java.util.EnumSet;
franta-hg@1
     9
import java.util.List;
franta-hg@1
    10
franta-hg@1
    11
/**
franta-hg@1
    12
 *
franta-hg@1
    13
 * @author Ing. František Kučera (frantovo.cz)
franta-hg@1
    14
 */
franta-hg@1
    15
public class CLIOptions {
franta-hg@1
    16
franta-hg@3
    17
	public static final String DEFAULT_NAME_PREFIX = ":";
franta-hg@1
    18
	private String sql;
franta-hg@1
    19
	private String databaseName;
franta-hg@15
    20
	private String databaseNameToTest;
franta-hg@3
    21
	private String namePrefix = DEFAULT_NAME_PREFIX;
franta-hg@14
    22
	private String formatterName;
franta-hg@1
    23
	private boolean batch;
franta-hg@2
    24
franta-hg@2
    25
	public enum MODE {
franta-hg@2
    26
franta-hg@2
    27
		QUERY_NOW,
franta-hg@2
    28
		PREPARE_BATCH,
franta-hg@14
    29
		EXECUTE_BATCH,
franta-hg@14
    30
		JUST_SHOW_INFO
franta-hg@14
    31
	}
franta-hg@14
    32
franta-hg@14
    33
	public enum INFO_TYPE {
franta-hg@14
    34
franta-hg@14
    35
		HELP,
franta-hg@14
    36
		VERSION,
franta-hg@14
    37
		LICENSE,
franta-hg@14
    38
		FORMATTERS,
franta-hg@15
    39
		TYPES,
franta-hg@15
    40
		DATABASES,
franta-hg@15
    41
		CONNECTION
franta-hg@2
    42
	}
franta-hg@1
    43
franta-hg@1
    44
	public enum COMMAND_TYPE {
franta-hg@1
    45
franta-hg@1
    46
		/** SELECT */
franta-hg@1
    47
		QUERY,
franta-hg@1
    48
		/** INSERT, UPDATE, DELETE */
franta-hg@1
    49
		UPDATE
franta-hg@1
    50
	};
franta-hg@1
    51
	private COMMAND_TYPE commandType;
franta-hg@1
    52
	private final Collection<NamedParameter> namedParameters = new ArrayList<>();
franta-hg@1
    53
	private final List<Parameter> numberedParameters = new ArrayList<>();
franta-hg@14
    54
	private final EnumSet<INFO_TYPE> showInfo = EnumSet.noneOf(INFO_TYPE.class);
franta-hg@1
    55
franta-hg@1
    56
	public void validate() throws InvalidOptionsException {
franta-hg@1
    57
		InvalidOptionsException e = new InvalidOptionsException();
franta-hg@1
    58
franta-hg@14
    59
		MODE mode = getMode();
franta-hg@14
    60
		if (mode == null) {
franta-hg@1
    61
			e.addProblem(new InvalidOptionsException.OptionProblem("Invalid combination of DB, SQL and BATCH – please specify just 2 of this 3 options"));
franta-hg@14
    62
		} else if (mode == MODE.JUST_SHOW_INFO) {
franta-hg@14
    63
			if (!namedParameters.isEmpty()) {
franta-hg@14
    64
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not use named parameters if just showing info."));
franta-hg@14
    65
			}
franta-hg@14
    66
			if (!numberedParameters.isEmpty()) {
franta-hg@14
    67
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not use numbered parameters if just showing info."));
franta-hg@14
    68
			}
franta-hg@14
    69
			if (isNotEmpty(sql, false)) {
franta-hg@14
    70
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not specify SQL if just showing info."));
franta-hg@14
    71
			}
franta-hg@14
    72
			if (isNotEmpty(databaseName, false)) {
franta-hg@14
    73
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not specify database if just showing info."));
franta-hg@14
    74
			}
franta-hg@14
    75
			if (batch) {
franta-hg@14
    76
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not specify batch if just showing info."));
franta-hg@14
    77
			}
franta-hg@14
    78
			if (isNotEmpty(formatterName, false)) {
franta-hg@14
    79
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not specify formatter if just showing info."));
franta-hg@14
    80
			}
franta-hg@14
    81
			if (!equalz(namePrefix, DEFAULT_NAME_PREFIX)) {
franta-hg@14
    82
				e.addProblem(new InvalidOptionsException.OptionProblem("Do not specify name prefix if just showing info."));
franta-hg@14
    83
			}
franta-hg@15
    84
			if (showInfo.contains(INFO_TYPE.CONNECTION) && isEmpty(databaseNameToTest, false)) {
franta-hg@15
    85
				e.addProblem(new InvalidOptionsException.OptionProblem("Please specify which database should be tested."));
franta-hg@15
    86
			}
franta-hg@1
    87
		}
franta-hg@1
    88
franta-hg@1
    89
		if (!namedParameters.isEmpty() && !numberedParameters.isEmpty()) {
franta-hg@1
    90
			e.addProblem(new InvalidOptionsException.OptionProblem("Named and numbered parameters can not be used together in one command."));
franta-hg@1
    91
		}
franta-hg@1
    92
franta-hg@1
    93
franta-hg@1
    94
		if (e.hasProblems()) {
franta-hg@1
    95
			throw e;
franta-hg@1
    96
		}
franta-hg@1
    97
	}
franta-hg@1
    98
franta-hg@2
    99
	private boolean hasSql() {
franta-hg@2
   100
		return isNotEmpty(getSql(), true);
franta-hg@1
   101
	}
franta-hg@1
   102
franta-hg@2
   103
	private boolean hasDb() {
franta-hg@2
   104
		return isNotEmpty(getDatabaseName(), true);
franta-hg@1
   105
	}
franta-hg@1
   106
franta-hg@2
   107
	/**
franta-hg@2
   108
	 * Depends on options: DB, BATCH, SQL
franta-hg@2
   109
	 *
franta-hg@2
   110
	 * @return mode | or null if options are not yet initialized or combination of options is
franta-hg@2
   111
	 * invalid
franta-hg@2
   112
	 */
franta-hg@2
   113
	public MODE getMode() {
franta-hg@2
   114
		if (hasDb() && !batch && hasSql()) {
franta-hg@2
   115
			return MODE.QUERY_NOW;
franta-hg@2
   116
		} else if (!hasDb() && batch && hasSql()) {
franta-hg@2
   117
			return MODE.PREPARE_BATCH;
franta-hg@2
   118
		} else if (hasDb() && batch && !hasSql()) {
franta-hg@2
   119
			return MODE.EXECUTE_BATCH;
franta-hg@2
   120
		} else {
franta-hg@14
   121
			return showInfo.isEmpty() ? null : MODE.JUST_SHOW_INFO;
franta-hg@2
   122
		}
franta-hg@2
   123
	}
franta-hg@2
   124
franta-hg@2
   125
	public String getSql() {
franta-hg@2
   126
		return sql;
franta-hg@2
   127
	}
franta-hg@2
   128
franta-hg@2
   129
	public void setSql(String sql) {
franta-hg@2
   130
		this.sql = sql;
franta-hg@2
   131
	}
franta-hg@2
   132
franta-hg@2
   133
	public String getDatabaseName() {
franta-hg@2
   134
		return databaseName;
franta-hg@2
   135
	}
franta-hg@2
   136
franta-hg@2
   137
	public void setDatabaseName(String databaseName) {
franta-hg@2
   138
		this.databaseName = databaseName;
franta-hg@2
   139
	}
franta-hg@2
   140
franta-hg@2
   141
	public void setBatch(boolean batch) {
franta-hg@2
   142
		this.batch = batch;
franta-hg@2
   143
	}
franta-hg@2
   144
franta-hg@2
   145
	public COMMAND_TYPE getCommandType() {
franta-hg@2
   146
		return commandType;
franta-hg@2
   147
	}
franta-hg@2
   148
franta-hg@2
   149
	public void setCommandType(COMMAND_TYPE commandType) {
franta-hg@2
   150
		this.commandType = commandType;
franta-hg@2
   151
	}
franta-hg@2
   152
franta-hg@2
   153
	public Collection<NamedParameter> getNamedParameters() {
franta-hg@2
   154
		return namedParameters;
franta-hg@2
   155
	}
franta-hg@2
   156
franta-hg@2
   157
	public List<Parameter> getNumberedParameters() {
franta-hg@2
   158
		return numberedParameters;
franta-hg@2
   159
	}
franta-hg@2
   160
franta-hg@2
   161
	public void addNumberedParameter(Parameter p) {
franta-hg@2
   162
		numberedParameters.add(p);
franta-hg@2
   163
	}
franta-hg@2
   164
franta-hg@2
   165
	public void addNamedParameter(NamedParameter p) {
franta-hg@2
   166
		namedParameters.add(p);
franta-hg@1
   167
	}
franta-hg@3
   168
franta-hg@3
   169
	public String getNamePrefix() {
franta-hg@3
   170
		return namePrefix;
franta-hg@3
   171
	}
franta-hg@3
   172
franta-hg@3
   173
	public void setNamePrefix(String namePrefix) {
franta-hg@3
   174
		this.namePrefix = namePrefix;
franta-hg@3
   175
	}
franta-hg@14
   176
franta-hg@14
   177
	public String getFormatterName() {
franta-hg@14
   178
		return formatterName;
franta-hg@14
   179
	}
franta-hg@14
   180
franta-hg@14
   181
	public void setFormatterName(String formatterName) {
franta-hg@14
   182
		this.formatterName = formatterName;
franta-hg@14
   183
	}
franta-hg@14
   184
franta-hg@14
   185
	public void addShowInfo(INFO_TYPE info) {
franta-hg@14
   186
		showInfo.add(info);
franta-hg@14
   187
	}
franta-hg@14
   188
franta-hg@14
   189
	public EnumSet<INFO_TYPE> getShowInfo() {
franta-hg@14
   190
		return showInfo;
franta-hg@14
   191
	}
franta-hg@15
   192
franta-hg@15
   193
	public String getDatabaseNameToTest() {
franta-hg@15
   194
		return databaseNameToTest;
franta-hg@15
   195
	}
franta-hg@15
   196
franta-hg@15
   197
	public void setDatabaseNameToTest(String databaseNameToTest) {
franta-hg@15
   198
		this.databaseNameToTest = databaseNameToTest;
franta-hg@15
   199
	}
franta-hg@1
   200
}