-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathProgram.cs
More file actions
52 lines (38 loc) · 1.38 KB
/
Copy pathProgram.cs
File metadata and controls
52 lines (38 loc) · 1.38 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
46
47
48
49
50
51
52
using Microsoft.EntityFrameworkCore;
using EntityFrameworkExample.Data;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllers();
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
String connectionString = Environment.GetEnvironmentVariable("DB");
if(connectionString == "sqlite") {
Console.WriteLine($"Using database connection {connectionString}");
builder.Services.AddDbContext<EntityContext>(
options => options.UseSqlite(builder.Configuration.GetConnectionString(connectionString))
);
} else {
connectionString = "postgres";
Console.WriteLine($"Using database connection {connectionString}");
builder.Services.AddDbContext<EntityContext>(
options => options.UseNpgsql(builder.Configuration.GetConnectionString(connectionString))
);
}
var app = builder.Build();
app.UseSwagger();
app.UseSwaggerUI(options =>
{
options.SwaggerEndpoint("/swagger/v1/swagger.json", "v1");
options.RoutePrefix = string.Empty;
});
using(var scope = app.Services.CreateScope())
{
var entityContext = scope.ServiceProvider.GetRequiredService<EntityContext>();
entityContext.Database.EnsureDeleted();
entityContext.Database.EnsureCreated();
entityContext.Seed();
}
// Configure the HTTP request pipeline.
app.UseAuthorization();
app.MapControllers();
app.Run();