LennonChin opened a new pull request, #7204:
URL: https://github.com/apache/kyuubi/pull/7204

   <!--
   Thanks for sending a pull request!
   
   Here are some tips for you:
     1. If this is your first time, please read our contributor guidelines: 
https://kyuubi.readthedocs.io/en/master/contributing/code/index.html
     2. If the PR is related to an issue in 
https://github.com/apache/kyuubi/issues, add '[KYUUBI #XXXX]' in your PR title, 
e.g., '[KYUUBI #XXXX] Your PR title ...'.
     3. If the PR is unfinished, add '[WIP]' in your PR title, e.g., 
'[WIP][KYUUBI #XXXX] Your PR title ...'.
   -->
   
   Spark Optimizer's ColumnPruning will replace `select(*)/select(1)` 
`Aggregate` plan's child to a `Project` node with empty projection list:
   
   ```scala
   object ColumnPruning extends Rule[LogicalPlan] {
     def apply(plan: LogicalPlan): LogicalPlan = removeProjectBeforeFilter(
       plan.transformWithPruning(AlwaysProcess.fn, ruleId) {
       ...
       // Prunes the unused columns from child of 
Aggregate/Expand/Generate/ScriptTransformation
       case a @ Aggregate(_, _, child) if 
!child.outputSet.subsetOf(a.references) =>
         a.copy(child = prunedChild(child, a.references))
       ...
   }
   ```
   
   but AuthZ plugin's `PrivilegesBuilder.buildQuery` method will ignore to 
check child node when plan's `inputSet` is empty, in this scenario, `Aggregate` 
node's child plan's privileges are ignored, which cause `select(*)/ select(1)` 
will ignored all privileges that should be checked.
   
   ### Why are the changes needed?
   <!--
   Please clarify why the changes are needed. For instance,
     1. If you propose a new API, clarify the use case for a new API.
     2. If you fix a bug, you can clarify why it is a bug, and what versions 
are affected.
   -->
   
   this patch add a holder node `ChildOutputHolder` when `Aggregate` node's 
`references` and it's child node's `outputSet` hava no intersection, it will 
hold the child node's `outputSet` used for build privilege objects, and 
`ChildOutputHolder` node will be eliminated after `RuleAuthorization` rule work 
completed.
   
   ### How was this patch tested?
   <!--
   If tests were added, say they were added here. Please make sure to add some 
test cases that check the changes thoroughly including negative and positive 
cases if possible.
   If it was tested in a way different from regular unit tests, please clarify 
how you tested step by step, ideally copy and paste-able, so that other 
reviewers can test and check, and descendants can verify in the future.
   If tests were not added, please describe why they were not added and/or why 
it was difficult to add.
   -->
   
   updated old unit tests and added new unit tests.
   
   ### Was this patch authored or co-authored using generative AI tooling?
   <!--
   If a generative AI tooling has been used in the process of authoring this 
patch, please include
   phrase 'Generated-by: ' followed by the name of the tool and its version.
   If no, write 'No'.
   Please refer to the [ASF Generative Tooling 
Guidance](https://www.apache.org/legal/generative-tooling.html) for details.
   -->
   
   No.
   
   


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to