package io.dropwizard.configuration;
import java.util.Collection;
Base class for problems with a Configuration object.
Refer to the implementations for different classes of problems:
- Parsing errors:
ConfigurationParsingException
- Validation errors:
ConfigurationValidationException
/**
* Base class for problems with a Configuration object.
* <p/>
* Refer to the implementations for different classes of problems:
* <ul>
* <li>Parsing errors: {@link ConfigurationParsingException}</li>
* <li>Validation errors: {@link ConfigurationValidationException}</li>
* </ul>
*/
public abstract class ConfigurationException extends Exception {
Auto-generated by Eclipse.
/**
* Auto-generated by Eclipse.
*/
private static final long serialVersionUID = 7596147083618606385L;
protected static final String NEWLINE = String.format("%n");
private final Collection<String> errors;
Creates a new ConfigurationException for the given path with the given errors.
Params: - path – the bad configuration path
- errors – the errors in the path
/**
* Creates a new ConfigurationException for the given path with the given errors.
*
* @param path the bad configuration path
* @param errors the errors in the path
*/
public ConfigurationException(String path, Collection<String> errors) {
super(formatMessage(path, errors));
this.errors = errors;
}
Creates a new ConfigurationException for the given path with the given errors and cause.
Params: - path – the bad configuration path
- errors – the errors in the path
- cause – the cause of the error(s)
/**
* Creates a new ConfigurationException for the given path with the given errors and cause.
*
* @param path the bad configuration path
* @param errors the errors in the path
* @param cause the cause of the error(s)
*/
public ConfigurationException(String path, Collection<String> errors, Throwable cause) {
super(formatMessage(path, errors), cause);
this.errors = errors;
}
public Collection<String> getErrors() {
return errors;
}
protected static String formatMessage(String file, Collection<String> errors) {
final StringBuilder msg = new StringBuilder(file);
msg.append(errors.size() == 1 ? " has an error:" : " has the following errors:").append(NEWLINE);
for (String error : errors) {
msg.append(" * ").append(error).append(NEWLINE);
}
return msg.toString();
}
}