我试图创建一个带有标记的掩蔽策略:
CREATE OR REPLACE MASKING POLICY TAGS_MASKING
AS (val VARCHAR, col_name STRING) RETURNS VARCHAR ->
CASE
WHEN CURRENT_ROLE() IN ('ADMIN_ROLE') THEN val
WHEN CURRENT_ROLE() IN ('ANALYST_ROLE') AND (SELECT SYSTEM$GET_TAG('TAG_NAME', col_name , 'COLUMN') = 'PUBLIC') THEN val
WHEN CURRENT_ROLE() IN ('ANALYST_ROLE') AND (SELECT SYSTEM$GET_TAG('TAG_NAME', col_name , 'COLUMN') IN ('PROTECTED')) THEN '****MASKED****'
END; 在这里,col_name是一个字符串(例如'mytable.col1'),因此我可以将这个掩蔽策略分配给我想要的任何列。但是,当我使用以下查询将其分配给一个表的一列时,它失败了:
ALTER TABLE IF EXISTS db.masking.mytable MODIFY COLUMN col1
SET MASKING POLICY TAGS_MASKING using (col1, 'mytable.col1');错误信息是:
语法错误:意外的"mytable.col1“
我该怎么想呢?谢谢!
发布于 2022-04-15 08:58:41
我还没有找到将列名参数化的方法(将它作为可选的第二个参数传递),所以我使用了不同的方法。
它使用雪花脚本自动创建每个colum的掩蔽策略。
设置:
CREATE OR REPLACE TAG TAG_NAME;
CREATE OR REPLACE TABLE mytable(col1 STRING);
ALTER TABLE mytable SET TAG TAG_NAME='PUBLIC';
INSERT INTO mytable(col1) VALUES ('Test');
SELECT * FROM mytable;
-- Test操作步骤:
CREATE OR REPLACE PROCEDURE test(schema_name STRING, tab_name STRING, col_name STRING)
RETURNS STRING
LANGUAGE SQL
AS
$$
DECLARE
sql_masking_policy STRING;
sql_alter_table STRING;
masking_policy_name STRING := CONCAT_WS('_', 'TAGS_MASKING_', SCHEMA_NAME, TAB_NAME, COL_NAME);
BEGIN
sql_masking_policy := '
CREATE OR REPLACE MASKING POLICY <masking_policy_name>
AS (val VARCHAR) RETURNS VARCHAR ->
CASE
WHEN CURRENT_ROLE() IN (''ADMIN_ROLE'') THEN val
WHEN CURRENT_ROLE() IN (''ANALYST_ROLE'') AND (SYSTEM$GET_TAG(''TAG_NAME'', ''<col_name>'', ''COLUMN'') = ''PUBLIC'') THEN val
WHEN CURRENT_ROLE() IN (''ANALYST_ROLE'') AND (SYSTEM$GET_TAG(''TAG_NAME'', ''<col_name>'', ''COLUMN'') IN (''PROTECTED'')) THEN ''****MASKED****''
END;';
sql_alter_table := 'ALTER TABLE IF EXISTS <tab_name> MODIFY COLUMN <col_name>
SET MASKING POLICY <masking_policy_name>;';
sql_masking_policy := REPLACE(sql_masking_policy, '<masking_policy_name>', :masking_policy_name);
sql_masking_policy := REPLACE(sql_masking_policy, '<col_name>', CONCAT_WS('.', schema_name, tab_name, col_name));
sql_alter_table := REPLACE(sql_alter_table, '<masking_policy_name>', :masking_policy_name);
sql_alter_table := REPLACE(sql_alter_table, '<tab_name>', CONCAT_WS('.', schema_name, tab_name));
sql_alter_table := REPLACE(sql_alter_table, '<col_name>', col_name);
EXECUTE IMMEDIATE :sql_masking_policy;
EXECUTE IMMEDIATE :sql_alter_table;
RETURN sql_masking_policy || CHR(10) || sql_alter_table;
END;
$$;呼叫:
CALL test('public', 'mytable', 'col1');输出:
CREATE OR REPLACE MASKING POLICY TAGS_MASKING__public_mytable_col1
AS (val VARCHAR) RETURNS VARCHAR ->
CASE
WHEN CURRENT_ROLE() IN ('ADMIN_ROLE') THEN val
WHEN CURRENT_ROLE() IN ('ANALYST_ROLE') AND (SYSTEM$GET_TAG('TAG_NAME', 'public.mytable.col1', 'COLUMN') = 'PUBLIC') THEN val
WHEN CURRENT_ROLE() IN ('ANALYST_ROLE') AND (SYSTEM$GET_TAG('TAG_NAME', 'public.mytable.col1', 'COLUMN') IN ('PROTECTED')) THEN '****MASKED****'
END;
ALTER TABLE IF EXISTS public.mytable MODIFY COLUMN col1 SET MASKING POLICY TAGS_MASKING__public_mytable_col1; 检查:
SHOW MASKING POLICIES;输出:

用上下文进行选材试验
execute using policy_context(current_role => 'PUBLIC')
AS
SELECT * FROM public.mytable;
-- NULL
execute using policy_context(current_role => 'ADMIN_ROLE')
AS
SELECT * FROM public.mytable;
-- Test
execute using policy_context(current_role => 'ANALYST_ROLE')
AS
SELECT * FROM public.mytable;
-- Test
ALTER TABLE mytable SET TAG TAG_NAME='PROTECTED';
execute using policy_context(current_role => 'ANALYST_ROLE')
AS
SELECT * FROM public.mytable;
-- ****MASKED****发布于 2022-07-01 20:43:07
基于标签的掩蔽策略结合了对象标记和掩蔽策略功能,允许使用ALTER命令在标记上设置掩蔽策略。当掩蔽策略签名中的数据类型与列的数据类型匹配时,标记的列将自动受到掩蔽策略中的条件的保护。这简化了数据保护工作,因为应该保护的列数据不再需要手动应用于列的掩蔽策略来保护数据。列可以通过直接分配给列的掩蔽策略和基于标记的掩蔽策略来保护。
SYSTEM$GET_TAG_ON_CURRENT_COLUMN( '‘) 根据指定的标记返回分配给列的标记字符串值,如果没有将标记分配给指定的列,则返回NULL。
对于这种情况:
CREATE OR REPLACE TAG TAG_NAME;
CREATE OR REPLACE MASKING POLICY TAGS_MASKING
AS (val VARCHAR) RETURNS VARCHAR ->
CASE
WHEN CURRENT_ROLE() IN ('ADMIN_ROLE') THEN val
WHEN CURRENT_ROLE() IN ('ANALYST_ROLE')
AND SYSTEM$GET_TAG_ON_CURRENT_COLUMN('TAG_NAME') = 'PUBLIC' THEN val
WHEN CURRENT_ROLE() IN ('ANALYST_ROLE')
AND SYSTEM$GET_TAG_ON_CURRENT_COLUMN('TAG_NAME') IN ('PROTECTED') THEN '****MASKED****'
END;
ALTER TAG TAG_NAME SET MASKING POLICY TAGS_MASKING;表:
CREATE OR REPLACE TABLE mytable(col1 STRING);
INSERT INTO mytable(col1) VALUES ('Test');
SELECT * FROM mytable;
-- COL1
-- Test赋值标签:
ALTER TABLE mytable ALTER COLUMN col1 SET TAG TAG_NAME='PROTECTED';角色外部ADMIN_ Role /分析师_ROLE:
SELECT * FROM mytable;
-- COL1
-- null切换到ANALYST_ROLE(带有PROTECTED值标记的列):
USE ROLE ANALYST_ROLE;
SELECT * FROM mytable;
-- COL1
-- ****MASKED****https://stackoverflow.com/questions/71880577
复制相似问题