BirthdayBot/Data/Database.cs

27 lines
952 B
C#
Raw Normal View History

using Npgsql;
using System.Threading.Tasks;
2021-10-18 23:14:46 +00:00
namespace BirthdayBot.Data;
internal static class Database {
public static string DBConnectionString { get; set; }
/// <summary>
2021-10-18 23:14:46 +00:00
/// Sets up and opens a database connection.
/// </summary>
2021-10-18 23:14:46 +00:00
public static async Task<NpgsqlConnection> OpenConnectionAsync() {
var db = new NpgsqlConnection(DBConnectionString);
await db.OpenAsync().ConfigureAwait(false);
return db;
}
2021-10-18 23:14:46 +00:00
public static async Task DoInitialDatabaseSetupAsync() {
using var db = await OpenConnectionAsync().ConfigureAwait(false);
2020-07-16 18:55:26 +00:00
2021-10-18 23:14:46 +00:00
// Refer to the methods being called for information on how the database is set up.
// Note: The order these are called is important. (Foreign reference constraints.)
await GuildConfiguration.DatabaseSetupAsync(db).ConfigureAwait(false);
await GuildUserConfiguration.DatabaseSetupAsync(db).ConfigureAwait(false);
}
}