-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathProgram.cs
More file actions
45 lines (34 loc) · 1.29 KB
/
Program.cs
File metadata and controls
45 lines (34 loc) · 1.29 KB
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
using Microsoft.AspNetCore.RateLimiting;
var builder = WebApplication.CreateSlimBuilder(args);
builder.Services
.AddErrorOrOpenApi()
.AddValidation()
.AddSingleton(TimeProvider.System)
.AddScoped<ITodoService, TodoService>()
.AddScoped<IOrderService, OrderService>();
builder.Services.AddErrorOrEndpoints()
.UseJsonContext<AppJsonSerializerContext>()
.WithCamelCase()
.WithIgnoreNulls();
// Services for AdminApi.cs middleware attributes ([Authorize], [EnableRateLimiting],
// [OutputCache], [EnableCors]). No authentication scheme is registered — wire your
// own to actually exercise [Authorize] endpoints (they 401 in this sample).
builder.Services.AddAuthorizationBuilder()
.AddPolicy("Admin", static p => p.RequireAuthenticatedUser());
builder.Services.AddRateLimiter(static options =>
options.AddFixedWindowLimiter("fixed", static o =>
{
o.PermitLimit = 10;
o.Window = TimeSpan.FromMinutes(1);
}));
builder.Services.AddOutputCache();
builder.Services.AddCors(static options =>
options.AddPolicy("Public", static p => p.AllowAnyOrigin().AllowAnyMethod().AllowAnyHeader()));
var app = builder.Build();
app.UseCors();
app.UseAuthorization();
app.UseRateLimiter();
app.UseOutputCache();
app.MapOpenApi();
app.MapErrorOrEndpoints();
app.Run();