微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何为尚未定义的函数授予 EXECUTE 权限

如何解决如何为尚未定义的函数授予 EXECUTE 权限

我正在运行一个 sql 脚本,该脚本首先创建一个用户,然后定义一些函数。如何在定义函数后不授予权限的情况下向 EXECUTE 尚未定义的函数授予权限?还有我将来定义的功能

我尝试过像这样更改认权限但没有成功:

alter default privileges for user admin in schema myschema
GRANT execute ON functions TO admin;

在像这样运行脚本后给予授权,但我不想每次定义新函数时都运行它:

grant execute on all functions in schema myschema to admin;

解决方法

您无需执行任何操作。只需继续阅读。

一旦您执行了 ALTER DEFAULT PRIVILEGES,就不再需要您建议的手动 GRANT。定义的权限是自动授予的,就像您希望的那样 - 对于定义的架构中定义的创建角色、定义的接收角色。

您的语句中确实有两次 admin,这是没有意义的,因为创建者是函数的初始所有者,并且引用 the manual

默认权限始终包括所有者的所有权限

您可能想在现代 Postgres(版本 11 或更高版本)中使用 ROUTINE 而不是 FUNCTIONThe manual on GRANT:

FUNCTION 语法适用于普通函数、聚合函数、 和窗口函数,但不适用于过程;使用 PROCEDURE 那些。或者,使用 ROUTINE 来引用一个函数,聚合 函数、窗口函数或过程,无论其精确度如何 类型。

但是(有点令人困惑)ALTER DEFAULT PRIVILEGES 上的手册是这样说的:

对于这个命令,函数包括聚合和过程。这 单词 FUNCTIONSROUTINES 在此命令中是等效的。 (ROUTINES 是首选的标准术语 功能和程序结合在一起。在早期的 PostgreSQL 中 版本,只允许使用 FUNCTIONS 一词。这是不可能的 分别为函数和过程设置默认权限。)

无论如何,ROUTINES 在现代 Postgres 中通常是正确的选择。在创建 creating_role 后运行:

ALTER DEFAULT PRIVILEGES FOR ROLE creating_role IN SCHEMA myschema
GRANT EXECUTE ON ROUTINES TO receiving_role;

然后,receiving_role 有权执行这些函数。 除了在标准设置中,PUBLIC 无论如何都有权执行。每个角色都自动成为 PUBLIC 的成员。 The manual:

对于其他类型的对象,授予 PUBLIC 的默认权限如下:[...] EXECUTE 函数和过程的权限;

所以你什么都不用做。

您是否知道 EXECUTE 的裸权限不提供除此之外的任何权限?尤其是,使用执行角色的权限访问表等。您可能正在寻找 SECURITY DEFINER functions。相关:

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。