HBASE-26019 Remove the reflection and call Configuration.getPassword() directly. (#3408)
Reviewed-by: Viraj Jasani <vjasani@apache.org> Reviewed-by: Wellington Chevreuil <wchevreuil@apache.org> Reviewed-by: litao <tomleescut@gmail.com>
This commit is contained in:
parent
1a9ddb6694
commit
cb247f9464
|
@ -200,36 +200,15 @@ public class HBaseConfiguration extends Configuration {
|
||||||
*/
|
*/
|
||||||
public static String getPassword(Configuration conf, String alias,
|
public static String getPassword(Configuration conf, String alias,
|
||||||
String defPass) throws IOException {
|
String defPass) throws IOException {
|
||||||
String passwd = null;
|
String passwd;
|
||||||
try {
|
char[] p = conf.getPassword(alias);
|
||||||
Method m = Configuration.class.getMethod("getPassword", String.class);
|
|
||||||
char[] p = (char[]) m.invoke(conf, alias);
|
|
||||||
if (p != null) {
|
if (p != null) {
|
||||||
LOG.debug(String.format("Config option \"%s\" was found through" +
|
LOG.debug("Config option {} was found through the Configuration getPassword method.", alias);
|
||||||
" the Configuration getPassword method.", alias));
|
|
||||||
passwd = new String(p);
|
passwd = new String(p);
|
||||||
} else {
|
} else {
|
||||||
LOG.debug(String.format(
|
LOG.debug("Config option {} was not found. Using provided default value", alias);
|
||||||
"Config option \"%s\" was not found. Using provided default value",
|
|
||||||
alias));
|
|
||||||
passwd = defPass;
|
passwd = defPass;
|
||||||
}
|
}
|
||||||
} catch (NoSuchMethodException e) {
|
|
||||||
// this is a version of Hadoop where the credential
|
|
||||||
//provider API doesn't exist yet
|
|
||||||
LOG.debug(String.format(
|
|
||||||
"Credential.getPassword method is not available." +
|
|
||||||
" Falling back to configuration."));
|
|
||||||
passwd = conf.get(alias, defPass);
|
|
||||||
} catch (SecurityException e) {
|
|
||||||
throw new IOException(e.getMessage(), e);
|
|
||||||
} catch (IllegalAccessException e) {
|
|
||||||
throw new IOException(e.getMessage(), e);
|
|
||||||
} catch (IllegalArgumentException e) {
|
|
||||||
throw new IOException(e.getMessage(), e);
|
|
||||||
} catch (InvocationTargetException e) {
|
|
||||||
throw new IOException(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
return passwd;
|
return passwd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue