-
Notifications
You must be signed in to change notification settings - Fork 3.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
sql: introduce the new role option SETPASSWORD
This commit introduces a new SQL-level role option (alongside LOGIN etc) called `SETPASSWORD`. This is used to control access to: - the `WITH PASSWORD` clause for `CREATE/ALTER USER/ROLE`: initializing, changing or removing password on users. - the `VALID UNTIL` clause for `CREATE/ALTER USER/ROLE`: changing the expiration date for a password. - `ALTER USER/ROLE SETPASSWORD/NOSETPASSWORD`: granting or removing the option for a user or role. This feature enables a site operator to separate the responsibility of administrating users and roles, which requires the CREATEROLE privilege, from that of administrating passwords, which now requires SETPASSWORD. For example, it can be used to ensure that no SQL client can choose their own passwords for users/roles, even if they are privileged enough to create new users or roles. Release note (security update): Initializing or changing the password of a SQL user, as well as setting the expiration date for a password, now requires the new `SETPASSWORD` option to be set for the requesting user or one of its roles. Previously, only the `CREATEROLE` option was sufficient to perform these changes. The pseudo-option `NOSETPASSWORD` can be used to revoke `SETPASSWORD`. The two predefined `root` and `admin` roles have the option `SETPASSWORD` set by default. Release note (security update): Only a user which already has option `SETPASSWORD` (either itself or one of its roles) can grant this option or use `NOSETPASSWORD`.
- Loading branch information
Showing
16 changed files
with
346 additions
and
145 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.