Skip to content

Commit

Permalink
sql: ensure schema only has valid privileges after reparent database …
Browse files Browse the repository at this point in the history
…is done

Release note (bug fix): Previously, ALTER DATABASE ... CONVERT TO SCHEMA
could potentially leave the schema with invalid privileges thus causing the
privilege descriptor to be invalid.
  • Loading branch information
RichardJCai committed May 27, 2021
1 parent 8d76190 commit 55986b3
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 0 deletions.
13 changes: 13 additions & 0 deletions pkg/sql/logictest/testdata/logic_test/reparent_database
Original file line number Diff line number Diff line change
Expand Up @@ -69,3 +69,16 @@ CREATE VIEW with_views.v AS SELECT x FROM with_views.t

statement error pq: could not convert database "with_views" into schema because "with_views.public.t" has dependent objects \[with_views.public.v\]
ALTER DATABASE with_views CONVERT TO SCHEMA WITH PARENT pgdatabase

# Ensure only valid privileges are copied over to the schema.
statement ok
CREATE DATABASE to_schema;
GRANT CREATE, DROP, SELECT, INSERT, DELETE, UPDATE ON DATABASE to_schema TO testuser;
CREATE DATABASE parent2;

# No privilege validation error should occur.
statement ok
ALTER DATABASE to_schema CONVERT TO SCHEMA WITH PARENT parent2;

statement ok
GRANT USAGE ON SCHEMA parent2.to_schema TO testuser;
11 changes: 11 additions & 0 deletions pkg/sql/reparent_database.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import (
"github.com/cockroachdb/cockroach/pkg/sql/catalog/typedesc"
"github.com/cockroachdb/cockroach/pkg/sql/pgwire/pgcode"
"github.com/cockroachdb/cockroach/pkg/sql/pgwire/pgerror"
"github.com/cockroachdb/cockroach/pkg/sql/privilege"
"github.com/cockroachdb/cockroach/pkg/sql/sem/tree"
"github.com/cockroachdb/cockroach/pkg/sql/sqlerrors"
"github.com/cockroachdb/cockroach/pkg/sql/sqltelemetry"
Expand Down Expand Up @@ -114,6 +115,16 @@ func (n *reparentDatabaseNode) startExec(params runParams) error {
if err != nil {
return err
}

// Not all Privileges on databases are valid on schemas.
// Remove any privileges that are not valid for schemas.
schemaPrivs := privilege.GetValidPrivilegesForObject(privilege.Schema).ToBitField()
privs := n.db.GetPrivileges()
for i, u := range privs.Users {
// Remove privileges that are valid for databases but not for schemas.
privs.Users[i].Privileges = u.Privileges & schemaPrivs
}

schema := schemadesc.NewBuilder(&descpb.SchemaDescriptor{
ParentID: n.newParent.ID,
Name: n.db.Name,
Expand Down

0 comments on commit 55986b3

Please sign in to comment.