-
Notifications
You must be signed in to change notification settings - Fork 3.1k
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
Improve access control check for MV #18371
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2193,6 +2193,7 @@ protected Scope visitTable(Table table, Optional<Scope> scope) | |
Optional<MaterializedViewDefinition> optionalMaterializedView = metadata.getMaterializedView(session, name); | ||
if (optionalMaterializedView.isPresent()) { | ||
MaterializedViewDefinition materializedViewDefinition = optionalMaterializedView.get(); | ||
analysis.addEmptyColumnReferencesForTable(accessControl, session.getIdentity(), name); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
change commit message to "Check materialized view access when no columns selected" |
||
if (isMaterializedViewSufficientlyFresh(session, name, materializedViewDefinition)) { | ||
// If materialized view is sufficiently fresh with respect to its grace period, answer the query using the storage table | ||
QualifiedName storageName = getMaterializedViewStorageTableName(materializedViewDefinition) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -158,15 +158,15 @@ protected SystemAccessControl delegate() | |
}) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
let's explain why it was incorrect |
||
.withGetViews((connectorSession, prefix) -> { | ||
ConnectorViewDefinition definitionRunAsDefiner = new ConnectorViewDefinition( | ||
"select 1", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Use capital letters for keywords |
||
"SELECT 1 AS test", | ||
Optional.of("mock"), | ||
Optional.of("default"), | ||
ImmutableList.of(new ConnectorViewDefinition.ViewColumn("test", BIGINT.getTypeId(), Optional.empty())), | ||
Optional.of("comment"), | ||
Optional.of("admin"), | ||
false); | ||
ConnectorViewDefinition definitionRunAsInvoker = new ConnectorViewDefinition( | ||
"select 1", | ||
"SELECT 1 AS test", | ||
Optional.of("mock"), | ||
Optional.of("default"), | ||
ImmutableList.of(new ConnectorViewDefinition.ViewColumn("test", BIGINT.getTypeId(), Optional.empty())), | ||
|
@@ -182,7 +182,7 @@ protected SystemAccessControl delegate() | |
public Map<SchemaTableName, ConnectorMaterializedViewDefinition> apply(ConnectorSession session, SchemaTablePrefix schemaTablePrefix) | ||
{ | ||
ConnectorMaterializedViewDefinition materializedViewDefinition = new ConnectorMaterializedViewDefinition( | ||
"select 1", | ||
"SELECT 1 AS test", | ||
Optional.empty(), | ||
Optional.empty(), | ||
Optional.empty(), | ||
|
@@ -253,7 +253,27 @@ public void testAccessControl() | |
assertAccessAllowed("SELECT name AS my_alias FROM nation", privilege("my_alias", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT my_alias from (SELECT name AS my_alias FROM nation)", privilege("my_alias", SELECT_COLUMN)); | ||
assertAccessDenied("SELECT name AS my_alias FROM nation", "Cannot select from columns \\[name] in table .*.nation.*", privilege("nation.name", SELECT_COLUMN)); | ||
|
||
assertAccessAllowed("SELECT 1 FROM mock.default.test_materialized_view"); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. add a test also for There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. does this add anything on top of There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't think so, but that assumption is based on knowledge how semantic analyzer works. It is a another way of reading no column data, so maybe it could trigger different execution path too. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. fine, but add a code comment explaining why we deem it worthwhile to fire up these two test queries, otherwise someone can just remove them saying they are redundant (because, in fact, they are) |
||
assertAccessDenied("SELECT 1 FROM mock.default.test_materialized_view", "Cannot select from columns.*", privilege("test_materialized_view", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT * FROM mock.default.test_materialized_view"); | ||
assertAccessDenied("SELECT * FROM mock.default.test_materialized_view", "Cannot select from columns.*", privilege("test_materialized_view", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT 1 FROM mock.default.test_view_definer"); | ||
assertAccessDenied("SELECT 1 FROM mock.default.test_view_definer", "Cannot select from columns.*", privilege("test_view_definer", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT * FROM mock.default.test_view_definer"); | ||
assertAccessDenied("SELECT * FROM mock.default.test_view_definer", "Cannot select from columns.*", privilege("test_view_definer", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT 1 FROM mock.default.test_view_invoker"); | ||
assertAccessDenied("SELECT 1 FROM mock.default.test_view_invoker", "Cannot select from columns.*", privilege("test_view_invoker", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT * FROM mock.default.test_view_invoker"); | ||
assertAccessDenied("SELECT * FROM mock.default.test_view_invoker", "Cannot select from columns.*", privilege("test_view_invoker", SELECT_COLUMN)); | ||
findepi marked this conversation as resolved.
Show resolved
Hide resolved
|
||
// with current implementation this next block of checks is redundant to `SELECT 1 FROM ..`, but it is not obvious unless details of how | ||
// semantics analyzer works are known | ||
assertAccessAllowed("SELECT count(*) FROM mock.default.test_materialized_view"); | ||
assertAccessDenied("SELECT count(*) FROM mock.default.test_materialized_view", "Cannot select from columns.*", privilege("test_materialized_view", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT count(*) FROM mock.default.test_view_invoker"); | ||
assertAccessDenied("SELECT count(*) FROM mock.default.test_view_invoker", "Cannot select from columns.*", privilege("test_view_invoker", SELECT_COLUMN)); | ||
assertAccessAllowed("SELECT count(*) FROM mock.default.test_view_definer"); | ||
assertAccessDenied("SELECT count(*) FROM mock.default.test_view_definer", "Cannot select from columns.*", privilege("test_view_definer", SELECT_COLUMN)); | ||
|
||
assertAccessDenied( | ||
"SELECT orders.custkey, lineitem.quantity FROM orders JOIN lineitem USING (orderkey)", | ||
"Cannot select from columns \\[orderkey, custkey] in table .*", | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you please add a test to
TestAccessControl
? This is a generic change for engine so we should have generic test coverage. I would even consider removing iceberg tests.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I will add a test there but I'd prefer to leave an Iceberg test as it exactly covers what was the original problem
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And perhaps also tests for regular views (if there aren't already), to make sure that they don't have the same issue.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
consider it done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What’s the original problem? Please add motivation and details in the PR description.