我想掌握在支持 Web 应用程序的多租户数据库中使用新行级安全功能的最佳方法。
目前,该应用程序有几个不同的可用角色,具体取决于它尝试采取的操作。
一旦应用程序使用自己的 ROLE 建立连接,应用程序就会将身份验证参数(由用户提供)传递到不同的函数中,这些函数会根据用户提供的身份验证参数过滤掉行。该系统旨在与成千上万的用户一起使用,并且似乎可以正常工作;然而,它显然很笨重(而且很慢)。
似乎如果我想使用新的行级安全功能,我需要为每个真实世界的用户(不仅仅是 Web 应用程序)创建一个新的角色来访问数据库。
这个对吗?如果是这样,在数据库中创建数千个角色是个好主意吗?
从评论中的a_horse_with_no_name链接更新(感谢,该线程是正确的):
CREATE USER application;
CREATE TABLE t1 (id int primary key, f1 text, app_user text);
INSERT INTO t1 VALUES(1,'a','bob');
INSERT INTO t1 VALUES(2,'b','alice');
ALTER TABLE t1 ENABLE ROW LEVEL SECURITY;
CREATE POLICY P ON t1 USING (app_user = current_setting('app_name.app_user'));
GRANT SELECT ON t1 TO application;
SET SESSION AUTHORIZATION application;
SET app_name.app_user = 'bob';
SELECT * FROM t1;
id | f1 | app_user
----+----+----------
1 | a | bob
(1 row)
SET app_name.app_user = 'alice';
SELECT * FROM t1;
id | f1 | app_user
----+----+----------
2 | b | alice
(1 row)
SET app_name.app_user = 'none';
SELECT * FROM t1;
id | f1 | app_user
----+----+----------
(0 rows)
现在,我很困惑,current_setting('app_name.app_user')
因为我的印象是这只适用于配置参数......在哪里app_name
定义?