Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[#5116][#5106][#4616][#5135] improve(auth-ranger): The owner of catalog/metalake should have all the privileges of schemas/tables #5113

Merged
merged 6 commits into from
Oct 21, 2024

Conversation

xunliu
Copy link
Member

@xunliu xunliu commented Oct 11, 2024

What changes were proposed in this pull request?

The owner of catalog/metalake should have all the privileges of schemas/tables.

Why are the changes needed?

Fix:

Does this PR introduce any user-facing change?

N/A

How was this patch tested?

Add ITs.

@xunliu xunliu requested a review from yuqi1129 October 11, 2024 13:56
@xunliu xunliu self-assigned this Oct 11, 2024
@xunliu xunliu marked this pull request as draft October 12, 2024 07:23
@xunliu xunliu force-pushed the issue-5106 branch 4 times, most recently from dcafa1d to b2cb8f2 Compare October 16, 2024 14:16
@xunliu xunliu changed the title [#5106] improve(auth-ranger): Filter Catalog securiable object in authorization Ranger [#5116][#5106][#4616][#5135] improve(auth-ranger): The owner of catalog/metalake should have all the privileges of schemas/tables Oct 16, 2024
@xunliu xunliu requested a review from jerqi October 16, 2024 14:29
@xunliu xunliu marked this pull request as ready for review October 17, 2024 01:10
@Override
public void close() throws IOException {}

public boolean validAuthorizationOperation(List<SecurableObject> securableObjects) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The package access level is sufficient.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

DONE

Comment on lines 664 to 689
return securableObjects.stream()
.noneMatch(
securableObject -> {
AtomicBoolean match = new AtomicBoolean(true);
securableObject.privileges().stream()
.forEach(
privilege -> {
if (!allowPrivilegesRule().contains(privilege.name())) {
LOG.error(
"Authorization to ignore privilege({}) on metadata object({})!",
privilege.name(),
securableObject.fullName());
match.set(false);
return;
}

if (!privilege.canBindTo(securableObject.type())) {
LOG.error(
"The privilege({}) is not supported for the metadata object({})!",
privilege.name(),
securableObject.fullName());
match.set(false);
}
});
return !match.get();
});
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
return securableObjects.stream()
.noneMatch(
securableObject -> {
AtomicBoolean match = new AtomicBoolean(true);
securableObject.privileges().stream()
.forEach(
privilege -> {
if (!allowPrivilegesRule().contains(privilege.name())) {
LOG.error(
"Authorization to ignore privilege({}) on metadata object({})!",
privilege.name(),
securableObject.fullName());
match.set(false);
return;
}
if (!privilege.canBindTo(securableObject.type())) {
LOG.error(
"The privilege({}) is not supported for the metadata object({})!",
privilege.name(),
securableObject.fullName());
match.set(false);
}
});
return !match.get();
});
return securableObjects.stream()
.allMatch(
securableObject -> {
AtomicBoolean match = new AtomicBoolean(true);
securableObject.privileges().stream()
.forEach(
privilege -> {
if (!allowPrivilegesRule().contains(privilege.name())) {
LOG.error(
"Authorization to ignore privilege({}) on metadata object({})!",
privilege.name(),
securableObject.fullName());
match.set(false);
return;
}
if (!privilege.canBindTo(securableObject.type())) {
LOG.error(
"The privilege({}) is not supported for the metadata object({})!",
privilege.name(),
securableObject.fullName());
match.set(false);
}
});
return match.get();
});

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

DONE

privilege -> {
if (!allowPrivilegesRule().contains(privilege.name())) {
LOG.error(
"Authorization to ignore privilege({}) on metadata object({})!",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since you are going to ignore privilege, why do you use the error level log and return false here?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The input privilege is not in the list of allowed privileges, so it needs to be ignored, and the error log output.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If so, I suggest the information 'xxxx privileges are not allowed/appliable for securable object xxxx'

/**
* Create a new role in the Ranger. <br>
* 1. Create a policy for metadata object. <br>
* 2. Save role name in the Policy items. <br>
*/
@Override
public Boolean onRoleCreated(Role role) throws RuntimeException {
rangerHelper.createRangerRoleIfNotExists(role.name());
if (!validAuthorizationOperation(role.securableObjects())) {
return false;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So I wonder what the return value means for onRoleCreated? what does the true and false means here?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tells the caller that the execution succeeded or failed

})
.collect(Collectors.toList());

if (matchPolicyItems.size() == 0) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

isEmpty()

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

DONE

DROP("drop"),
ALTER("alter"),
INDEX("index"),
LOCK("lock"),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What's the meaning of lock privilege?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is hive privilege.

@xunliu
Copy link
Member Author

xunliu commented Oct 19, 2024

hi @yuqi1129 Please help me review this PR again, Thanks.

@yuqi1129
Copy link
Contributor

I have no further comments regarding pure code logic. @jerqi Do you have any further comments?

@jerqi
Copy link
Contributor

jerqi commented Oct 21, 2024

I have no further comments regarding pure code logic. @jerqi Do you have any further comments?

I have no further comment.

Copy link
Contributor

@yuqi1129 yuqi1129 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

Copy link
Contributor

@yuqi1129 yuqi1129 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@yuqi1129 yuqi1129 merged commit 7a050d6 into apache:main Oct 21, 2024
26 checks passed
mplmoknijb pushed a commit to mplmoknijb/gravitino that referenced this pull request Nov 6, 2024
…ger): The owner of catalog/metalake should have all the privileges of schemas/tables (apache#5113)

### What changes were proposed in this pull request?

The owner of catalog/metalake should have all the privileges of schemas/tables.

### Why are the changes needed?

Fix: 
- apache#5116
- apache#5106
- apache#4616
- apache#5135

### Does this PR introduce _any_ user-facing change?

N/A

### How was this patch tested?

Add ITs.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants