forked from svanvliet/acs-messaging-app
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Startup.cs
74 lines (64 loc) · 2.81 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
71
72
73
74
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Components;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.ResponseCompression;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using SVV.MessagingApp.Data;
namespace SVV.MessagingApp
{
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.
// For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
public void ConfigureServices(IServiceCollection services)
{
services.AddRazorPages();
services.AddServerSideBlazor();
services.AddMvc();
// Adding a singleton instance of the MessageThreadService for injection and use in our Razor pages
services.AddSingleton<MessageThreadService>();
// Adding SignalR support so that we can handle webhook calls from EventGrid. Note that we also need to handle
// the compression MIME type so that we can decompress the JSON payload from EventGrid calls
services.AddSignalR();
services.AddResponseCompression(opts => {
opts.MimeTypes = ResponseCompressionDefaults.MimeTypes
.Concat(new []{"application/octet-stream"});
});
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
}
app.UseStaticFiles();
app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
// Mappin the SignalR hubs we need to handle and process the events received from EventGrid.
// For purposes of this demo, we are only handling two events - Validation (which is required
// to wire-up on the EventGrid sid), and the inbound SMS event.
endpoints.MapBlazorHub();
endpoints.MapHub<Hubs.SmsHub>("smshub");
endpoints.MapFallbackToPage("/_Host");
});
}
}
}