-
Notifications
You must be signed in to change notification settings - Fork 253
/
Copy pathProgram.cs
65 lines (49 loc) · 2.13 KB
/
Program.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
using Microsoft.Data.SqlClient;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Steeltoe.Configuration.CloudFoundry;
using Steeltoe.Connectors.EntityFrameworkCore.SqlServer;
using Steeltoe.Connectors.SqlServer;
using Steeltoe.Management.Endpoint.Actuators.All;
using Steeltoe.Samples.SqlServerEFCore;
using Steeltoe.Samples.SqlServerEFCore.Data;
WebApplicationBuilder builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllersWithViews();
// Steeltoe: Add Cloud Foundry Configuration Provider for Actuator integration (not required for connectors).
builder.AddCloudFoundryConfiguration();
// Steeltoe: Add actuator endpoints.
builder.Services.AddAllActuators();
// Steeltoe: Setup SQL Server options, connection factory and health checks.
builder.AddSqlServer();
// Steeltoe: optionally change the SQL Server connection string at runtime.
builder.Services.Configure<SqlServerOptions>(options =>
{
var connectionStringBuilder = new SqlConnectionStringBuilder
{
ConnectionString = options.ConnectionString,
["Max Pool Size"] = 50
};
options.ConnectionString = connectionStringBuilder.ConnectionString;
});
// Steeltoe: Setup DbContext connection string, optionally changing SQL Server options at runtime.
builder.Services.AddDbContext<AppDbContext>((serviceProvider, options) => options.UseSqlServer(serviceProvider, null, untypedOptions =>
{
var sqlServerOptions = (SqlServerDbContextOptionsBuilder)untypedOptions;
sqlServerOptions.EnableRetryOnFailure();
}));
WebApplication app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Home/Error");
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.MapControllerRoute("default", "{controller=Home}/{action=Index}/{id?}");
// Steeltoe: Insert some rows into SQL Server table.
await SqlServerSeeder.CreateSampleDataAsync(app.Services);
app.Run();