-
-
Notifications
You must be signed in to change notification settings - Fork 99
/
Copy pathProgram.cs
51 lines (45 loc) · 1.99 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
using System;
using System.IO;
using System.Reflection;
using System.Text.RegularExpressions;
using DbUp;
using HappyCode.NetCoreBoilerplate.Db.Options;
using Microsoft.Extensions.Configuration;
namespace HappyCode.NetCoreBoilerplate.Db
{
class Program
{
public static int Main(string[] args)
{
var configuration = LoadAppConfiguration();
var upgradeOptions = configuration.GetSection("UpgradeOptions").Get<UpgradeOptions>();
var scriptsAndCodePatternPattern = new Regex(upgradeOptions.ScriptsAndCodePattern ?? ".*", RegexOptions.IgnoreCase | RegexOptions.Compiled);
var upgrader = DeployChanges.To
.SqlDatabase(configuration.GetConnectionString("MsSqlDb"))
.WithScriptsAndCodeEmbeddedInAssembly(Assembly.GetExecutingAssembly(), (fileName) => scriptsAndCodePatternPattern.IsMatch(fileName))
.WithExecutionTimeout(TimeSpan.FromSeconds(upgradeOptions.CommandExecutionTimeoutSeconds))
.WithTransaction()
.LogToConsole()
.Build();
var result = upgrader.PerformUpgrade();
if (!result.Successful)
{
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine(result.Error);
return -1;
}
Console.ForegroundColor = ConsoleColor.Green;
Console.WriteLine("Success!");
return 0;
}
private static IConfigurationRoot LoadAppConfiguration()
{
return new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddJsonFile($"appsettings.{Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT") ?? "Production"}.json", optional: true)
.AddEnvironmentVariables()
.Build();
}
}
}