mirror of
https://github.com/zoriya/Kyoo.git
synced 2025-05-24 02:02:36 -04:00
76 lines
2.3 KiB
C#
76 lines
2.3 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using Kyoo.Abstractions.Controllers;
|
|
using Microsoft.AspNetCore.Hosting;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.Extensions.Configuration;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using Microsoft.Extensions.Hosting;
|
|
using Npgsql;
|
|
|
|
namespace Kyoo.Postgresql
|
|
{
|
|
/// <summary>
|
|
/// A module to add postgresql capacity to the app.
|
|
/// </summary>
|
|
public class PostgresModule : IPlugin
|
|
{
|
|
/// <inheritdoc />
|
|
public string Slug => "postgresql";
|
|
|
|
/// <inheritdoc />
|
|
public string Name => "Postgresql";
|
|
|
|
/// <inheritdoc />
|
|
public string Description => "A database context for postgresql.";
|
|
|
|
/// <inheritdoc />
|
|
public Dictionary<string, Type> Configuration => new();
|
|
|
|
/// <inheritdoc />
|
|
public bool Enabled => _configuration.GetSelectedDatabase() == "postgres";
|
|
|
|
/// <summary>
|
|
/// The configuration to use. The database connection string is pulled from it.
|
|
/// </summary>
|
|
private readonly IConfiguration _configuration;
|
|
|
|
/// <summary>
|
|
/// The host environment to check if the app is in debug mode.
|
|
/// </summary>
|
|
private readonly IWebHostEnvironment _environment;
|
|
|
|
/// <summary>
|
|
/// Create a new postgres module instance and use the given configuration and environment.
|
|
/// </summary>
|
|
/// <param name="configuration">The configuration to use</param>
|
|
/// <param name="env">The environment that will be used (if the env is in development mode, more information will be displayed on errors.</param>
|
|
public PostgresModule(IConfiguration configuration, IWebHostEnvironment env)
|
|
{
|
|
_configuration = configuration;
|
|
_environment = env;
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void Configure(IServiceCollection services)
|
|
{
|
|
services.AddDbContext<DatabaseContext, PostgresContext>(x =>
|
|
{
|
|
x.UseNpgsql(_configuration.GetDatabaseConnection("postgres"));
|
|
if (_environment.IsDevelopment())
|
|
x.EnableDetailedErrors().EnableSensitiveDataLogging();
|
|
}, ServiceLifetime.Transient);
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void Initialize(IServiceProvider provider)
|
|
{
|
|
DatabaseContext context = provider.GetRequiredService<DatabaseContext>();
|
|
context.Database.Migrate();
|
|
|
|
using NpgsqlConnection conn = (NpgsqlConnection)context.Database.GetDbConnection();
|
|
conn.Open();
|
|
conn.ReloadTypes();
|
|
}
|
|
}
|
|
} |