Row based access policy
Overview
1. We have a BI tool, with many named users.
2. Users log in using their email id and password and view different reports/dashboards.
3. Reports/dashboards fetch data from Vertica database using generic user 'dw_readonly' and password (In a prebuilt connection of BI Tool).
4. I would like to implement a row level security so that user can access only specific client's data which is maintained in another table within two columns -> business_user_id integer, client_id integer.
5. Business users and clients have many to many relationship.
Problem
Dynamic implementation of row level security, without creating as many roles or users because BI Tool is using the prebuilt connection with user 'dw_readonly'.
0
Comments
Hi!
Can BI Tool do a complex logic while connecting to Vertica?
For example:
label = 'foo'
label = 'foo'
In any case, somehow Vertica should determine users to apply policy and it should be reflected in connection params. If each connection uses in same params so Im afraid it's not possible.
Per @sKwa's suggestion, below is a quick example:
Here is the table I want to limit row access:
Here is a lookup table that lists the users and the rows they can see:
Here is an access policy:
Now I cannot read data from the test table:
Until my BI tool (or vsql in this example) sets the session label:
See:
https://my.vertica.com/docs/9.0.x/HTML/index.htm#Authoring/SQLReferenceManual/Functions/VerticaFunctions/ConnectionManagement/SET_CLIENT_LABEL.htm
Note, Tableau can run the Vertica SET_CLIENT_LABEL function via the " Run Initial SQL" option:
See:
http://onlinehelp.tableau.com/current/pro/desktop/en-us/help.html#connect_basic_initialsql.html
Excellent!! Thanks for the nice explanation!!