forked from brunobritodev/JPProject.IdentityServer4.AdminUI
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDbSettingsConfig.cs
More file actions
54 lines (52 loc) · 2.05 KB
/
DbSettingsConfig.cs
File metadata and controls
54 lines (52 loc) · 2.05 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
53
54
using Jp.Infra.Data.MySql.Configuration;
using Jp.Infra.Data.PostgreSQL.Configuration;
using Jp.Infra.Data.Sql.Configuration;
using Jp.Infra.Data.Sqlite.Configuration;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
namespace Jp.Infra.CrossCutting.Database
{
public static class DbSettingsConfig
{
public static void ConfigureDatabase(this IServiceCollection services, IConfiguration configuration)
{
var database = configuration["ApplicationSettings:DatabaseType"].ToUpper();
var connString = configuration.GetConnectionString("SSOConnection");
switch (database)
{
case "MYSQL":
services.AddIdentityMySql(connString);
break;
case "SQLSERVER":
services.AddIdentitySqlServer(connString);
break;
case "POSTGRESQL":
services.AddIdentityPostgreSql(connString);
break;
case "SQLITE":
services.AddIdentitySqlite(connString);
break;
}
}
public static void ConfigureIdentityServerDatabase(this IIdentityServerBuilder builder, IConfiguration configuration)
{
var database = configuration["ApplicationSettings:DatabaseType"].ToUpper();
var connString = configuration.GetConnectionString("SSOConnection");
switch (database)
{
case "MYSQL":
builder.UseIdentityServerMySqlDatabase(connString);
break;
case "SQLSERVER":
builder.UseIdentityServerSqlDatabase(connString);
break;
case "POSTGRESQL":
builder.UseIdentityServerPostgreSqlDatabase(connString);
break;
case "SQLITE":
builder.UseIdentityServerSqlite(connString);
break;
}
}
}
}