forked from alexyz79/pdf-online-signature
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathStartup.cs
70 lines (61 loc) · 2.87 KB
/
Startup.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Org.BouncyCastle.Asn1.X509;
using PDFOnlineSignature.Core.Render;
using PDFOnlineSignature.Models;
using PDFOnlineSignature.Core.Trust.Authentication;
namespace PDFOnlineSignature {
public class Startup {
public Startup (IConfiguration configuration) {
Configuration = configuration;
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices (IServiceCollection services) {
services.AddMvc ();
string DataSource = "Data Source=" + Configuration["PDFOnlineSignature:DataSource"];
if (Configuration["PDFOnlineSignature:DatabaseDriver"] == "SqlLite") {
services.AddDbContext<PDFOnlineSignatureContext> (
options => options.UseSqlite (DataSource)
);
}
// Add framework services.
services.AddSingleton<IConfiguration> (Configuration);
services.AddScoped<IViewRenderService, ViewRenderService> ();
services.AddMvc ();
services.AddAuthentication (options => {
options.DefaultAuthenticateScheme = CertificateAuthenticationDefaults.AuthenticationScheme;
options.DefaultChallengeScheme = CertificateAuthenticationDefaults.AuthenticationScheme;
})
.AddCertificateAuthentication (certOptions => { });
services.AddAuthorization (options => {
options.AddPolicy ("CanAccessAdminMethods", policy => policy.RequireRole ("Admin"));
options.AddPolicy ("CanAccessOperatorMethods", policy => policy.RequireRole ("Operator"));
options.AddPolicy ("CanAccessReviewerMethods", policy => policy.RequireRole ("Reviewer"));
});
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure (IApplicationBuilder app, IHostingEnvironment env) {
if (env.IsDevelopment ()) {
app.UseDeveloperExceptionPage ();
} else {
app.UseExceptionHandler ("/Home/Error");
}
app.UseStaticFiles ();
app.UseAuthentication ();
app.UseMvc (routes => {
routes.MapRoute (
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
}
}
}