Skip to content

This example shows how you can implement connection filtering in an application, where users share the same application.

License

Notifications You must be signed in to change notification settings

DevExpress-Examples/asp-net-core-dashboard-row-level-security

Repository files navigation

BI Dashboard for ASP NET.Core - Row-Level Security

This example implements connection filtering for dashboards in multi-user environments. The application sets the current user ID within SESSION_CONTEXT. When the database connection opens, security policies filter visible rows for the current user.

Example Overview

Configure a Database

  1. This example uses a SQL file (instnwnd.sql). Execute it to recreate the database locally. Do not forget to update appsettings.json and Program.cs: so that the connection string works in your environment.

  2. Execute the script below. The script extends the database as follows:

  • Creates a new schema and predicate function, which uses user ID stored in SESSION_CONTEXT to filter rows.
  • Creates a security policy that adds this function as a filter predicate and a block predicate on Orders.
CREATE SCHEMA Security;
GO

CREATE FUNCTION Security.fn_securitypredicate(@EmployeeId int)
    RETURNS TABLE
    WITH SCHEMABINDING
AS
    RETURN SELECT 1 AS fn_securitypredicate_result
    WHERE CAST(SESSION_CONTEXT(N'EmployeeId') AS int) = @EmployeeId;
GO

CREATE SECURITY POLICY Security.OrdersFilter
    ADD FILTER PREDICATE Security.fn_securitypredicate(EmployeeId)
        ON dbo.Orders,
    ADD BLOCK PREDICATE Security.fn_securitypredicate(EmployeeId)
        ON dbo.Orders AFTER INSERT
    WITH (STATE = ON);
GO

Configure the IDBConnectionInterceptor Object

Create an IDBConnectionInterceptor object (RLSConnectionInterceptor.cs in this example). When the database connection opens, store the current user ID in SESSION_CONTEXT. Modify queries for the Orders table - filter data by user ID (so as to implement database behavior equivalent to connection filtering).

Register RLSConnectionInterceptor within DashboardConfigurator.

Run the Application

When you run the application, a registration form (Login.cshtml) will appear on-screen.

Registration form

Select a user to generate a dashboard with filtered data.

Dashboard

Files to Review

Does this example address your development requirements/objectives?

(you will be redirected to DevExpress.com to submit your response)

About

This example shows how you can implement connection filtering in an application, where users share the same application.

Topics

Resources

License

Stars

Watchers

Forks