- Purpose of the article: In this blog, we have explained clearly about the row access policy and column level security from the users.
- Intended Audience: this POC/blog will help for the people to mask an important or sensitive data from the users.
- Tools and Technology: Snowflake(snowsight).
- Key words: Row access policy from user (data masking).
What’s data masking:
Data masking creates a fake data with realistic interpretation of orginal data.
Types of data masking:
- Column level security (dynamic data masking)
- Row level Security
Dynamic data masking:
Dynamic data masking is a masking policy for a column that has formally loaded as a understandable (text) format in Snowflake.
Row level Security:
Row level Security is useful to return the specified rows from the table through from the query.
Uses of data masking:
- Protects sensitive data from third party systems
- Reduces data loss and risks
Flowchart:
data:image/s3,"s3://crabby-images/5d356/5d3568a50a28acc1681e827789125ea0ff66c3f6" alt=""
Way to create Data masking in Snowsight
- Step-1: Create account and login to the snowsight and go for worksheet.
- Step-2: Create a data warehouse to collect data from many data sources.
data:image/s3,"s3://crabby-images/4136d/4136db7fbd291ed1016562841d2cb53b11f16b65" alt=""
- Step-3: Create a database, create table and insert values into it. Here we have created secure_db database and within the secure_db database we have created secure_db table.
data:image/s3,"s3://crabby-images/0f91d/0f91dc1678633d0358710c1d44a13fb9d9174886" alt=""
- Step-4: Insert the values in the table.
data:image/s3,"s3://crabby-images/c52d4/c52d47fa3c81a4e19ac181037d47a45dd049a0a2" alt=""
- Step-5: Use role Accountadmin to create a masking policy for a column.
data:image/s3,"s3://crabby-images/2d465/2d465b807b2349a985c9cfb4ab181e04758b1bf1" alt=""
- Step-6: Apply that column level masking policy to the column in the table.
data:image/s3,"s3://crabby-images/eb290/eb290a40f5eb99e21f98613f1b9ed62d64964295" alt=""
- Step-7: As we are in Accountadmin the data is visible.
data:image/s3,"s3://crabby-images/e88d0/e88d0f6689b278a8ff42f614d7e654fd5db58449" alt=""
- Step-8: Now change the role and then see the data in the table. (Phone_number column in the table is masked)
data:image/s3,"s3://crabby-images/3c66b/3c66beacdf2fbc04ec566d603cb5a33d9a21672b" alt=""
- Step-9: Let’s create a mapping table which is used for filtering the rows or which rows in the table must be visible for the specified user.
data:image/s3,"s3://crabby-images/c39c7/c39c70da4ecd8ad16a93ebe30f5d3be6dfae343b" alt=""
- Step-10: Insert the values into the mapping table.
data:image/s3,"s3://crabby-images/e817c/e817c427331ea654b6ab91f9c1210eadb12bae5e" alt=""
- Step-11: Now let’s create a row access policy for a column in the table (datamask). Here we have created a row access policy for a job_id column in the datamask table.
data:image/s3,"s3://crabby-images/5d526/5d526cf03017452ef6009f512c72cab8fd80ce54" alt=""
Step-12: Add that masking policy to the column in table.
data:image/s3,"s3://crabby-images/1b416/1b41663f356209d8a7f00da20ccb1532705cd2e9" alt=""
- Step-13: Select the data from the table. As it is in Accountadmin the data is visible.
data:image/s3,"s3://crabby-images/b9b8f/b9b8f3cc139f01b054e6caf2f56f9bbabd526639" alt=""
- Step-14: Now create a role for the roles in the filtering table.
data:image/s3,"s3://crabby-images/f8035/f80352487797a4547e4c3985f7f3084d7b41443a" alt=""
- Step-15: Grant t permission on usage of warehouse for the created roles.
data:image/s3,"s3://crabby-images/fd21c/fd21cb1fcda772e626b1f4305f258fcb5ca1afca" alt=""
- Step-16: Grant permission on usage of database for the created roles.
data:image/s3,"s3://crabby-images/1ad75/1ad7552cd9e2d321b1abe30f0b6a86aa2f51ea63" alt=""
- Step-17: Grant permission on usage of schema for the created roles.
data:image/s3,"s3://crabby-images/85e68/85e68f617095247ce16f2f5f86749ede050bcfd5" alt=""
- Step-18: Grant permission on usage of tables for the created roles.
data:image/s3,"s3://crabby-images/ca119/ca1199c91f03cd8f163297d8f5d125e048c9a190" alt=""
- Step-19: Now let’s create a user and grant permission of a role to that user.
data:image/s3,"s3://crabby-images/88dab/88dab1df79a67588b45821ace5225c271d67734e" alt=""
- Step-20: Open a new table and login with user credentials.
data:image/s3,"s3://crabby-images/8cc1b/8cc1be18c0a6c9c3c153756f3d2d7777d48d488d" alt=""
- Step-21: Within the worksheets, you can see the role and warehouse of a generaluser. Here for SYSROLE role I have assigned all the dept_names.
data:image/s3,"s3://crabby-images/810e0/810e015988a58b88d561bbb4220ec6af19e38924" alt=""
- Step-22: By using that role and data warehouse you can access the table.
data:image/s3,"s3://crabby-images/3affe/3affe50cb3dce12a8733894e84d65fe4dfae0f78" alt=""
- Step-23: Here we can see the three job_ids that are assigned for generaluser.
data:image/s3,"s3://crabby-images/fb056/fb056f139450a77f0f9c3839f7cb6d364fd832cf" alt=""
- Step-24: Now create a new user and grant the permission of a role to that user.
data:image/s3,"s3://crabby-images/caf51/caf5124ad5119a117dcd18cc6f69b61a80ea1b59" alt=""
- Step-25: Now login with the new credentials.
data:image/s3,"s3://crabby-images/bec78/bec787095b9f36e98b7be86b95c1740f68142cad" alt=""
- Step-26: By using the role and data warehouse you can access the table. Here for USROLE role I have assigned only the IT_PROG dept_names.
data:image/s3,"s3://crabby-images/f0625/f06250b682bf465988690feddb3ecf3afd1c4b9f" alt=""
- Step-27: Here we can see only one job_id that are assigned to restricted user.
data:image/s3,"s3://crabby-images/6c9c3/6c9c325fd9bf6f89f742dcefd4d8c5f667f5939d" alt=""
Author Bio:
data:image/s3,"s3://crabby-images/65085/650855a3c7b90668645ac564e072deaee17fe662" alt="Picture of Thanusha Payyavula"
Thanusha Payyavula
Associate Software Engineer
I am Thanusha Payyavula working as Associate Software Engineering at Mouri Tech for the past 1.5 years. I have good experience in SQL, Snowflake, AWS, and Qlikview. I have been involved in multiple projects where I have worked with multiple technologies and been involved in a couple of activities to find the solution in project deliverables. .