HBASE-13239 HBase grant at specific column level does not work for Groups
This commit is contained in:
parent
cb4db89bff
commit
189424e6fc
|
@ -295,7 +295,7 @@ public class TableAuthManager {
|
|||
}
|
||||
}
|
||||
} else if (LOG.isDebugEnabled()) {
|
||||
LOG.debug("No permissions found");
|
||||
LOG.debug("No permissions found for " + action);
|
||||
}
|
||||
|
||||
return false;
|
||||
|
@ -488,20 +488,26 @@ public class TableAuthManager {
|
|||
* permissions.
|
||||
*/
|
||||
public boolean authorizeGroup(String groupName, Permission.Action action) {
|
||||
return authorize(globalCache.getGroup(groupName), action);
|
||||
List<Permission> perms = globalCache.getGroup(groupName);
|
||||
if (LOG.isDebugEnabled()) {
|
||||
LOG.debug("authorizing " + (perms != null && !perms.isEmpty() ? perms.get(0) : "") +
|
||||
" for " + action);
|
||||
}
|
||||
return authorize(perms, action);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks authorization to a given table and column family for a group, based
|
||||
* Checks authorization to a given table, column family and column for a group, based
|
||||
* on the stored permissions.
|
||||
* @param groupName
|
||||
* @param table
|
||||
* @param family
|
||||
* @param qualifier
|
||||
* @param action
|
||||
* @return true if known and authorized, false otherwise
|
||||
*/
|
||||
public boolean authorizeGroup(String groupName, TableName table, byte[] family,
|
||||
Permission.Action action) {
|
||||
byte[] qualifier, Permission.Action action) {
|
||||
// Global authorization supercedes table level
|
||||
if (authorizeGroup(groupName, action)) {
|
||||
return true;
|
||||
|
@ -513,7 +519,13 @@ public class TableAuthManager {
|
|||
return true;
|
||||
}
|
||||
// Check table level
|
||||
return authorize(getTablePermissions(table).getGroup(groupName), table, family, action);
|
||||
List<TablePermission> tblPerms = getTablePermissions(table).getGroup(groupName);
|
||||
if (LOG.isDebugEnabled()) {
|
||||
LOG.debug("authorizing " + (tblPerms != null && !tblPerms.isEmpty() ? tblPerms.get(0) : "") +
|
||||
" for " +groupName + " on " + table + "." + Bytes.toString(family) + "." +
|
||||
Bytes.toString(qualifier) + " with " + action);
|
||||
}
|
||||
return authorize(tblPerms, table, family, qualifier, action);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -548,7 +560,7 @@ public class TableAuthManager {
|
|||
String[] groups = user.getGroupNames();
|
||||
if (groups != null) {
|
||||
for (String group : groups) {
|
||||
if (authorizeGroup(group, table, family, action)) {
|
||||
if (authorizeGroup(group, table, family, qualifier, action)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue