To run the sample solution. Everything is self-contained.
1. Unzip
2. Open solution
3. Clean Solution (Roslyn compiler issue)
4. run
Sample Solution Setup
Created a new project ASP.NET Web Application (.NET Framework)
Enter the name of the project
Choose Single Page Application
Install NuGet package Hangfire
Add local database under App_Data
Set web.config connectionStrings section to
Add new class HangfireAuthorizationFilter.cs
**nore [assembly: OwinStartup(typeof(HangfireDashboardAuth.Startup))] this will be different depending what the project name space is.
Change Startup.cs
data:image/s3,"s3://crabby-images/9178f/9178f7a968956457d17b958029b7c61cf5568bfd" alt=""
using Microsoft.Owin;
using Owin;
using Hangfire;
[assembly: OwinStartup(typeof(HangfireDashboardAuth.Startup))]
namespace HangfireDashboardAuth
{
public partial class Startup
{
public void Configuration(IAppBuilder app)
{
ConfigureAuth(app);
GlobalConfiguration.Configuration.UseSqlServerStorage("DefaultConnection");
app.UseHangfireDashboard("/hangfire", new DashboardOptions
{
Authorization = new[] { new HangfireAuthorizationFilter()
}
});
}
}
}
Double click on Hangfire.mdf, there are no tables.
data:image/s3,"s3://crabby-images/75326/753264b602e6ee422570eeef5eb723ddfc90a45e" alt=""
(Hangfire auto-creates the Hangfire tables when there are no Hangfire tables present)
To do this start the application (F5), should land on the default page
data:image/s3,"s3://crabby-images/19992/19992b34e0631d8d7f6985cb2059f47dd9273cae" alt=""
Navigate to https://localhost:44388/hangfire it will auto redirect back to the login page thanks to the HangfireAuthorizationFilter.
Back at the database, the Hangfire tables have been created.
data:image/s3,"s3://crabby-images/426e1/426e1ce1bae6466fdb340529a751f15b8d0c4898" alt=""
Create ASP net tables
Try to login
data:image/s3,"s3://crabby-images/19f95/19f95def5639db175ea23a4af63a601f26cfafea" alt=""
data:image/s3,"s3://crabby-images/9b7e1/9b7e100928ecf48a19411af64f58575ae3874fcd" alt=""
Click Register
data:image/s3,"s3://crabby-images/d59b0/d59b06a044469672438bc2028aeba97a9abfb2a8" alt=""
Add the following users for testing
admin@test.com
readonly@test.com
Should now see the new users.
data:image/s3,"s3://crabby-images/e3bca/e3bcaba42c6dcfea8f7ebb4f32d39716fc32d01b" alt=""
Add Roles
Run the following script
INSERT INTO AspNetRoles (Id, Name) VALUES ('4f6e6a25-e532-423f-ba60-88bdae3ef6b8', 'HangfireAdmin')
INSERT INTO AspNetRoles (Id, Name) VALUES ('f222ed9b-354d-4621-bfaf-8e8d21276ac2', 'HangfireReadOnly')
Associate admin@test.com to the role HangfireAdmin
data:image/s3,"s3://crabby-images/226d2/226d2ba35f4f5187151d52b7edad59164a1cc4bc" alt=""
Test
1. Not logged in, try to navigate to https://localhost:44388/hangfire will auto redirect to the login page
2. Login as readonly@test.com, and try to navigate to https://localhost:44388/hangfire
403 Error returned because the user is not associated to HangfireAdmin role.
data:image/s3,"s3://crabby-images/f2938/f29383fa85f2a61fc38cc53b5f7cb778b0b70778" alt=""
3. Login as admin@test.com, and try to navigate to https://localhost:44388/hangfire
data:image/s3,"s3://crabby-images/08a8f/08a8f5a4f832d8cb0c28b72e4f6bc1d9bf0f95fc" alt=""