-
Notifications
You must be signed in to change notification settings - Fork 765
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
feat(query): grant object visibility check #14458
Conversation
cc @flaneur2020 wait auth check built in role |
a89dbd9
to
bd8263c
Compare
f84e4cb
to
28c0486
Compare
IHMO, it's always showing databases/tables from effective roles. |
related PR: #14451 |
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.
LGTM
45ac3d1
to
0c40999
Compare
cc @BohuTANG This pr can be review. And old query normal user need do this grant after upgrade. Note: Now create database need create database privilege. If you want to create a database, should excute grant create database on *.* to <user_name> Or grant create database on *.* to role <role_name>;
grant role <role_name> to <user_name>; |
Good. |
Create database will return err. Need root user do this Ref #14458 (comment) |
Docker Image for PR
|
SummaryI test on my local with standalone mode. The same error was repeated. Meta version v1.2.262 Query version : old-version(1.2.314) -> upgrade to pr version -> rollback to old-version(1.2.314). How to producemeta version: v1.2.262-37e04b9922-simd query version: MySQL [(none)]> create role test;
Query OK, 0 rows affected (0.033 sec)
MySQL [(none)]> grant all on *.* to role test;
Query OK, 0 rows affected (0.020 sec)
MySQL [(none)]> select version();
+----------------------------------------------------------------------------------------+
| version() |
+----------------------------------------------------------------------------------------+
| 8.0.26-v1.2.314-nightly-3ccec470ea(rust-1.77.0-nightly-2024-01-27T16:50:23.223949439Z) |
+----------------------------------------------------------------------------------------+
1 row in set (0.012 sec)
query version: MySQL [(none)]> create user u1 identified by '123';
Query OK, 0 rows affected (0.026 sec)
MySQL [(none)]> grant all on *.* to u1;
Query OK, 0 rows affected (0.023 sec)
rollback to rebuild query, and try to run it. failed:
Analyzedebug log in pb :
And this err is serde json err
if deserialize struct err, will degrade to serje json. So we should focus on the pb deserialize err. It looks like an incompatible design here. At this point, this pr contains the value CreateDatabase, which was not recognized by older versions. So the judgment fails. |
Which PR and where is this incompatibility triggered? |
3f05049
to
0503f85
Compare
In pr #14501, we modify deserialize bitflag way. Now use from_bits_truncate. So if this pr revert to before version https://github.com/datafuselabs/databend/releases/tag/v1.2.321-nightly, may cause a compatibility problem |
2eebf14
to
2837ec7
Compare
Modify: 1. all users can see informatio_schema and system. 2, show databases/tables only display current role owned object. if set secondary role all, will display all effective roles owned object. 3. add new privilege type : CreateDatabase. It's a global object. 4. create udf and create index need super privilege. Note: Now create database need create database privilege. If you want to create a database, should excute `grant create database on *.* to <user_name> or ```sql grant create database on *.* to role <role_name>; grant role <role_name> to <user_name>; ```
8ae1cb3
to
d3427f2
Compare
d3427f2
to
726881e
Compare
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.
Reviewed 2 of 6 files at r3, 1 of 6 files at r4, all commit messages.
Reviewable status: 3 of 14 files reviewed, 2 unresolved discussions (waiting on @flaneur2020, @JackTan25, and @TCeason)
src/meta/app/src/principal/user_privilege.rs
line 77 at r4 (raw file):
Write = 1 << 19, // Privilege to Create database CreateDatabase = 1 << 20,
Is this new field compatible with old version of databend-query? i.e., what if an old query reads this value 1<<20
but it does not have this type CreateDatabase
?
after this pr #14458 (comment) will ignore the unknown bit. |
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.
Reviewed 2 of 13 files at r1, 1 of 4 files at r2, 2 of 6 files at r3, 5 of 6 files at r4.
Reviewable status: 13 of 14 files reviewed, 2 unresolved discussions (waiting on @flaneur2020 and @JackTan25)
I test this pr on test-cloud env. And now ci has forward compat test already passed. Shell we merge this pr? cc @BohuTANG show warehouses;
│ pc-test_priv │ Suspended │ XSmall │ │ 600 │ NULL │ 2024-02-19 06:31:50 │
│ tai-test_priv │ Suspended │ XSmall │ pr-14458-8283a6f │ 600 │ NULL │ 2024-02-19 06:49:35 │ |
I hereby agree to the terms of the CLA available at: https://docs.databend.com/dev/policies/cla/
Summary
Modify:
all users can see informatio_schema and system.
show databases/tables only display current role owned object. if set
secondary role all, will display all effective roles owned object.
add new privilege type : CreateDatabase. It's a global object.
create udf and create index need super privilege.
drop database need check Database level drop privilege
Note:
Now create database need create database privilege.
If you want to create a database, should excute
Or
Tests
Type of change
This change isdata:image/s3,"s3://crabby-images/d0bb7/d0bb7f7625ca5bf5c3cf7a2b7a514cf841ab8395" alt="Reviewable"