Configure ASP.NET for the API to work #7
							
								
								
									
										36
									
								
								Endpoint/ConfigureSwaggerOptions.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								Endpoint/ConfigureSwaggerOptions.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,36 @@
 | 
			
		||||
using Microsoft.AspNetCore.Mvc.ApiExplorer;
 | 
			
		||||
using Microsoft.Extensions.DependencyInjection;
 | 
			
		||||
using Microsoft.Extensions.Options;
 | 
			
		||||
using Microsoft.OpenApi.Models;
 | 
			
		||||
using Swashbuckle.AspNetCore.SwaggerGen;
 | 
			
		||||
using System;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint;
 | 
			
		||||
 | 
			
		||||
public class ConfigureSwaggerOptions(IApiVersionDescriptionProvider provider) : IConfigureOptions<SwaggerGenOptions>
 | 
			
		||||
{
 | 
			
		||||
    public void Configure(SwaggerGenOptions options)
 | 
			
		||||
    {
 | 
			
		||||
        foreach (var description in provider.ApiVersionDescriptions)
 | 
			
		||||
        {
 | 
			
		||||
            options.SwaggerDoc(description.GroupName, CreateInfoForApiVersion(description));
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private static OpenApiInfo CreateInfoForApiVersion(ApiVersionDescription description)
 | 
			
		||||
    {
 | 
			
		||||
        var info = new OpenApiInfo()
 | 
			
		||||
        {
 | 
			
		||||
            Title = "MIREA Schedule Web API",
 | 
			
		||||
            Version = description.ApiVersion.ToString(),
 | 
			
		||||
            Description = "This API provides a convenient interface for retrieving data stored in the database. Special attention was paid to the lightweight and easy transfer of all necessary data. Made by the Winsomnia team.",
 | 
			
		||||
            Contact = new OpenApiContact { Name = "Author name", Email = "support@winsomnia.net" },
 | 
			
		||||
            License = new OpenApiLicense { Name = "MIT", Url = new Uri("https://opensource.org/licenses/MIT") }
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        if (description.IsDeprecated)
 | 
			
		||||
            info.Description += " This API version has been deprecated.";
 | 
			
		||||
 | 
			
		||||
        return info;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -1,36 +0,0 @@
 | 
			
		||||
using System;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using Microsoft.AspNetCore.Mvc;
 | 
			
		||||
using Microsoft.Extensions.Logging;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint.Controllers;
 | 
			
		||||
 | 
			
		||||
[ApiController]
 | 
			
		||||
[Route("[controller]")]
 | 
			
		||||
public class WeatherForecastController : ControllerBase
 | 
			
		||||
{
 | 
			
		||||
    private static readonly string[] Summaries = new[]
 | 
			
		||||
    {
 | 
			
		||||
            "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    private readonly ILogger<WeatherForecastController> _logger;
 | 
			
		||||
 | 
			
		||||
    public WeatherForecastController(ILogger<WeatherForecastController> logger)
 | 
			
		||||
    {
 | 
			
		||||
        _logger = logger;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    [HttpGet(Name = "GetWeatherForecast")]
 | 
			
		||||
    public IEnumerable<WeatherForecast> Get()
 | 
			
		||||
    {
 | 
			
		||||
        return Enumerable.Range(1, 5).Select(index => new WeatherForecast
 | 
			
		||||
        {
 | 
			
		||||
            Date = DateOnly.FromDateTime(DateTime.Now.AddDays(index)),
 | 
			
		||||
            TemperatureC = Random.Shared.Next(-20, 55),
 | 
			
		||||
            Summary = Summaries[Random.Shared.Next(Summaries.Length)]
 | 
			
		||||
        })
 | 
			
		||||
        .ToArray();
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -11,15 +11,25 @@
 | 
			
		||||
		<AssemblyName>Mirea.Api.Endpoint</AssemblyName>
 | 
			
		||||
		<RootNamespace>$(AssemblyName)</RootNamespace>
 | 
			
		||||
		<OutputType>Exe</OutputType>
 | 
			
		||||
		<InvariantGlobalization>true</InvariantGlobalization>
 | 
			
		||||
		<InvariantGlobalization>false</InvariantGlobalization>
 | 
			
		||||
		<UserSecretsId>65cea060-88bf-4e35-9cfb-18fc996a8f05</UserSecretsId>
 | 
			
		||||
		<DockerDefaultTargetOS>Linux</DockerDefaultTargetOS>
 | 
			
		||||
		<DockerfileContext>.</DockerfileContext>
 | 
			
		||||
		<SignAssembly>False</SignAssembly>
 | 
			
		||||
		<GenerateDocumentationFile>True</GenerateDocumentationFile>
 | 
			
		||||
		<DocumentationFile>docs.xml</DocumentationFile>
 | 
			
		||||
		<NoWarn>$(NoWarn);1591</NoWarn>
 | 
			
		||||
	</PropertyGroup>
 | 
			
		||||
 | 
			
		||||
	<ItemGroup>
 | 
			
		||||
		<PackageReference Include="Microsoft.VisualStudio.Azure.Containers.Tools.Targets" Version="1.19.5" />
 | 
			
		||||
		<PackageReference Include="Swashbuckle.AspNetCore" Version="6.5.0" />
 | 
			
		||||
		<PackageReference Include="Swashbuckle.AspNetCore.Versioning" Version="2.0.0" />
 | 
			
		||||
	</ItemGroup>
 | 
			
		||||
 | 
			
		||||
	<ItemGroup>
 | 
			
		||||
		<ProjectReference Include="..\Domain\Domain.csproj" />
 | 
			
		||||
		<ProjectReference Include="..\Persistence\Persistence.csproj" />
 | 
			
		||||
	</ItemGroup>
 | 
			
		||||
 | 
			
		||||
</Project>
 | 
			
		||||
							
								
								
									
										24
									
								
								Endpoint/EnvironmentManager.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								Endpoint/EnvironmentManager.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,24 @@
 | 
			
		||||
using System;
 | 
			
		||||
using System.IO;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint;
 | 
			
		||||
 | 
			
		||||
internal static class EnvironmentManager
 | 
			
		||||
{
 | 
			
		||||
    public static void LoadEnvironment(string filePath)
 | 
			
		||||
    {
 | 
			
		||||
        if (!File.Exists(filePath)) return;
 | 
			
		||||
 | 
			
		||||
        foreach (var line in File.ReadAllLines(filePath))
 | 
			
		||||
        {
 | 
			
		||||
            var parts = line.Split(
 | 
			
		||||
                '=',
 | 
			
		||||
                StringSplitOptions.RemoveEmptyEntries);
 | 
			
		||||
 | 
			
		||||
            if (parts.Length != 2)
 | 
			
		||||
                continue;
 | 
			
		||||
 | 
			
		||||
            Environment.SetEnvironmentVariable(parts[0].Trim(), parts[1][..(parts[1].Contains('#') ? parts[1].IndexOf('#') : parts[1].Length)].Trim());
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -1,29 +1,114 @@
 | 
			
		||||
using Microsoft.AspNetCore.Builder;
 | 
			
		||||
using Microsoft.AspNetCore.Mvc;
 | 
			
		||||
using Microsoft.AspNetCore.Mvc.ApiExplorer;
 | 
			
		||||
using Microsoft.AspNetCore.Mvc.Versioning;
 | 
			
		||||
using Microsoft.Extensions.Configuration;
 | 
			
		||||
using Microsoft.Extensions.DependencyInjection;
 | 
			
		||||
using Microsoft.Extensions.Hosting;
 | 
			
		||||
using Microsoft.Extensions.Options;
 | 
			
		||||
using Mirea.Api.DataAccess.Application;
 | 
			
		||||
using Mirea.Api.DataAccess.Persistence;
 | 
			
		||||
using Mirea.Api.Endpoint.Properties;
 | 
			
		||||
using Swashbuckle.AspNetCore.SwaggerGen;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Collections;
 | 
			
		||||
using System.IO;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint;
 | 
			
		||||
 | 
			
		||||
public class Program
 | 
			
		||||
{
 | 
			
		||||
    private static IConfigurationRoot ConfigureEnvironment()
 | 
			
		||||
    {
 | 
			
		||||
        EnvironmentManager.LoadEnvironment(".env");
 | 
			
		||||
        var environmentVariables = Environment.GetEnvironmentVariables()
 | 
			
		||||
            .OfType<DictionaryEntry>()
 | 
			
		||||
            .ToDictionary(
 | 
			
		||||
                entry => entry.Key.ToString() ?? string.Empty,
 | 
			
		||||
                entry => entry.Value?.ToString() ?? string.Empty
 | 
			
		||||
            );
 | 
			
		||||
 | 
			
		||||
        var result = new ConfigurationBuilder().AddInMemoryCollection(environmentVariables!);
 | 
			
		||||
 | 
			
		||||
        return result.Build();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static void Main(string[] args)
 | 
			
		||||
    {
 | 
			
		||||
        Directory.SetCurrentDirectory(AppDomain.CurrentDomain.BaseDirectory);
 | 
			
		||||
 | 
			
		||||
        var builder = WebApplication.CreateBuilder(args);
 | 
			
		||||
        builder.Configuration.AddConfiguration(ConfigureEnvironment());
 | 
			
		||||
        builder.Configuration.AddJsonFile(Settings.FilePath, optional: true, reloadOnChange: true);
 | 
			
		||||
 | 
			
		||||
        // Add services to the container.
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddApplication();
 | 
			
		||||
        builder.Services.AddPersistence(builder.Configuration);
 | 
			
		||||
        builder.Services.AddControllers();
 | 
			
		||||
        // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddCors(options =>
 | 
			
		||||
        {
 | 
			
		||||
            options.AddPolicy("AllowAll", policy =>
 | 
			
		||||
            {
 | 
			
		||||
                policy.AllowAnyHeader();
 | 
			
		||||
                policy.AllowAnyMethod();
 | 
			
		||||
                policy.AllowAnyOrigin();
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddApiVersioning(options =>
 | 
			
		||||
        {
 | 
			
		||||
            options.DefaultApiVersion = new ApiVersion(1, 0);
 | 
			
		||||
            options.AssumeDefaultVersionWhenUnspecified = true;
 | 
			
		||||
            options.ReportApiVersions = true;
 | 
			
		||||
            options.ApiVersionReader = new UrlSegmentApiVersionReader();
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddVersionedApiExplorer(options =>
 | 
			
		||||
        {
 | 
			
		||||
            options.GroupNameFormat = "'v'VVV";
 | 
			
		||||
            options.SubstituteApiVersionInUrl = true;
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddEndpointsApiExplorer();
 | 
			
		||||
        builder.Services.AddSwaggerGen();
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddSwaggerGen(options =>
 | 
			
		||||
        {
 | 
			
		||||
            options.OperationFilter<SwaggerDefaultValues>();
 | 
			
		||||
            var basePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory);
 | 
			
		||||
 | 
			
		||||
            var xmlPath = Path.Combine(basePath, "docs.xml");
 | 
			
		||||
            options.IncludeXmlComments(xmlPath);
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        builder.Services.AddTransient<IConfigureOptions<SwaggerGenOptions>, ConfigureSwaggerOptions>();
 | 
			
		||||
 | 
			
		||||
        var app = builder.Build();
 | 
			
		||||
 | 
			
		||||
#if DEBUG
 | 
			
		||||
        // Write configurations
 | 
			
		||||
        foreach (var item in app.Configuration.AsEnumerable())
 | 
			
		||||
            Console.WriteLine($"{item.Key}:{item.Value}");
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
        var uber = app.Services.CreateScope().ServiceProvider.GetService<UberDbContext>();
 | 
			
		||||
        DbInitializer.Initialize(uber!);
 | 
			
		||||
 | 
			
		||||
        // Configure the HTTP request pipeline.
 | 
			
		||||
        if (app.Environment.IsDevelopment())
 | 
			
		||||
        {
 | 
			
		||||
            app.UseSwagger();
 | 
			
		||||
            app.UseSwaggerUI();
 | 
			
		||||
            app.UseSwaggerUI(options =>
 | 
			
		||||
            {
 | 
			
		||||
                var provider = app.Services.GetService<IApiVersionDescriptionProvider>();
 | 
			
		||||
 | 
			
		||||
                foreach (var description in provider!.ApiVersionDescriptions)
 | 
			
		||||
                {
 | 
			
		||||
                    var url = $"/swagger/{description.GroupName}/swagger.json";
 | 
			
		||||
                    var name = description.GroupName.ToUpperInvariant();
 | 
			
		||||
                    options.SwaggerEndpoint(url, name);
 | 
			
		||||
                }
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        app.UseHttpsRedirection();
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										36
									
								
								Endpoint/Properties/Settings.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								Endpoint/Properties/Settings.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,36 @@
 | 
			
		||||
using Mirea.Api.DataAccess.Persistence.Properties;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint.Properties;
 | 
			
		||||
 | 
			
		||||
public class EmailSettings
 | 
			
		||||
{
 | 
			
		||||
    public string? Server { get; set; }
 | 
			
		||||
    public string? User { get; set; }
 | 
			
		||||
    public string? Password { get; set; }
 | 
			
		||||
    public string? From { get; set; }
 | 
			
		||||
    public int? Port { get; set; }
 | 
			
		||||
    public bool? Ssl { get; set; }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
public class LogSettings
 | 
			
		||||
{
 | 
			
		||||
    public bool EnableLogToFile { get; set; }
 | 
			
		||||
    public string? LogFilePath { get; set; }
 | 
			
		||||
    public string? LogFileName { get; set; }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
public class ScheduleSettings
 | 
			
		||||
{
 | 
			
		||||
    // Every 6 hours
 | 
			
		||||
    public string CronUpdateSchedule { get; set; } = "0 0 0/6 * * *";
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
public class Settings
 | 
			
		||||
{
 | 
			
		||||
    public const string FilePath = "Settings.json";
 | 
			
		||||
 | 
			
		||||
    public EmailSettings? EmailSettings { get; set; }
 | 
			
		||||
    public LogSettings? LogSettings { get; set; }
 | 
			
		||||
    public DbSettings? DbSettings { get; set; }
 | 
			
		||||
    public ScheduleSettings? ScheduleSettings { get; set; }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										55
									
								
								Endpoint/SwaggerDefaultValues.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								Endpoint/SwaggerDefaultValues.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,55 @@
 | 
			
		||||
using Microsoft.AspNetCore.Mvc.ApiExplorer;
 | 
			
		||||
using Microsoft.AspNetCore.Mvc.ModelBinding;
 | 
			
		||||
using Microsoft.OpenApi.Models;
 | 
			
		||||
using Swashbuckle.AspNetCore.SwaggerGen;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using System.Text.Json;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint;
 | 
			
		||||
 | 
			
		||||
public class SwaggerDefaultValues : IOperationFilter
 | 
			
		||||
{
 | 
			
		||||
    public void Apply(OpenApiOperation operation, OperationFilterContext context)
 | 
			
		||||
    {
 | 
			
		||||
        var apiDescription = context.ApiDescription;
 | 
			
		||||
        operation.Deprecated |= apiDescription.IsDeprecated();
 | 
			
		||||
 | 
			
		||||
        foreach (var responseType in context.ApiDescription.SupportedResponseTypes)
 | 
			
		||||
        {
 | 
			
		||||
            var responseKey = responseType.IsDefaultResponse ? "default" : responseType.StatusCode.ToString();
 | 
			
		||||
            var response = operation.Responses[responseKey];
 | 
			
		||||
 | 
			
		||||
            foreach (var contentType in response.Content.Keys)
 | 
			
		||||
            {
 | 
			
		||||
                if (responseType.ApiResponseFormats.All(x => x.MediaType != contentType))
 | 
			
		||||
                {
 | 
			
		||||
                    response.Content.Remove(contentType);
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (operation.Parameters == null)
 | 
			
		||||
        {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        foreach (var parameter in operation.Parameters)
 | 
			
		||||
        {
 | 
			
		||||
            var description = apiDescription.ParameterDescriptions.First(p => p.Name == parameter.Name);
 | 
			
		||||
 | 
			
		||||
            parameter.Description ??= description.ModelMetadata?.Description;
 | 
			
		||||
 | 
			
		||||
            if (parameter.Schema.Default == null &&
 | 
			
		||||
                description.DefaultValue != null &&
 | 
			
		||||
                description.DefaultValue is not DBNull &&
 | 
			
		||||
                description.ModelMetadata is ModelMetadata modelMetadata)
 | 
			
		||||
            {
 | 
			
		||||
                var json = JsonSerializer.Serialize(description.DefaultValue, modelMetadata.ModelType);
 | 
			
		||||
                parameter.Schema.Default = OpenApiAnyFactory.CreateFromJson(json);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            parameter.Required |= description.IsRequired;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -1,14 +0,0 @@
 | 
			
		||||
using System;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.Endpoint;
 | 
			
		||||
 | 
			
		||||
public class WeatherForecast
 | 
			
		||||
{
 | 
			
		||||
    public DateOnly Date { get; set; }
 | 
			
		||||
 | 
			
		||||
    public int TemperatureC { get; set; }
 | 
			
		||||
 | 
			
		||||
    public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
 | 
			
		||||
 | 
			
		||||
    public string? Summary { get; set; }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										11
									
								
								Persistence/DbInitializer.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								Persistence/DbInitializer.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,11 @@
 | 
			
		||||
using Microsoft.EntityFrameworkCore;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.DataAccess.Persistence;
 | 
			
		||||
 | 
			
		||||
public static class DbInitializer
 | 
			
		||||
{
 | 
			
		||||
    public static void Initialize(DbContext dbContext)
 | 
			
		||||
    {
 | 
			
		||||
        dbContext.Database.EnsureCreated();
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										64
									
								
								Persistence/DependencyInjection.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								Persistence/DependencyInjection.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,64 @@
 | 
			
		||||
using Microsoft.EntityFrameworkCore;
 | 
			
		||||
using Microsoft.Extensions.Configuration;
 | 
			
		||||
using Microsoft.Extensions.DependencyInjection;
 | 
			
		||||
using Mirea.Api.DataAccess.Application.Interfaces.DbContexts.Schedule;
 | 
			
		||||
using Mirea.Api.DataAccess.Persistence.Contexts.Schedule;
 | 
			
		||||
using Mirea.Api.DataAccess.Persistence.Properties;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
 | 
			
		||||
namespace Mirea.Api.DataAccess.Persistence;
 | 
			
		||||
 | 
			
		||||
public static class DependencyInjection
 | 
			
		||||
{
 | 
			
		||||
    public static IServiceCollection AddPersistence(this IServiceCollection services, IConfiguration configuration)
 | 
			
		||||
    {
 | 
			
		||||
        var settings = configuration.GetSection(nameof(DbSettings)).Get<DbSettings>();
 | 
			
		||||
        var connection = settings?.ConnectionStringSql;
 | 
			
		||||
 | 
			
		||||
        Dictionary<DatabaseEnum, Action<DbContextOptionsBuilder>> dbConfigurations = new()
 | 
			
		||||
        {
 | 
			
		||||
            {
 | 
			
		||||
                DatabaseEnum.Mysql,
 | 
			
		||||
                options => options.UseMySql(connection, ServerVersion.AutoDetect(connection))
 | 
			
		||||
            },
 | 
			
		||||
            {
 | 
			
		||||
                DatabaseEnum.Sqlite,
 | 
			
		||||
                options => options.UseSqlite(connection)
 | 
			
		||||
            },
 | 
			
		||||
            {
 | 
			
		||||
                DatabaseEnum.PostgresSql,
 | 
			
		||||
                options => options.UseNpgsql(connection)
 | 
			
		||||
            }
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        if (dbConfigurations.TryGetValue((DatabaseEnum)settings?.TypeDatabase!, out var dbConfig))
 | 
			
		||||
        {
 | 
			
		||||
            services.AddDbContext<CampusDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<DisciplineDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<FacultyDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<GroupDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<LectureHallDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<LessonAssociationDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<ProfessorDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<LessonDbContext>(dbConfig);
 | 
			
		||||
            services.AddDbContext<TypeOfOccupationDbContext>(dbConfig);
 | 
			
		||||
 | 
			
		||||
            services.AddDbContext<UberDbContext>(dbConfig);
 | 
			
		||||
        }
 | 
			
		||||
        else
 | 
			
		||||
            throw new NotSupportedException("Unsupported database type");
 | 
			
		||||
 | 
			
		||||
        services.AddScoped<ICampusDbContext>(provider => provider.GetService<CampusDbContext>()!);
 | 
			
		||||
        services.AddScoped<IDisciplineDbContext>(provider => provider.GetService<DisciplineDbContext>()!);
 | 
			
		||||
        services.AddScoped<IFacultyDbContext>(provider => provider.GetService<FacultyDbContext>()!);
 | 
			
		||||
        services.AddScoped<IGroupDbContext>(provider => provider.GetService<GroupDbContext>()!);
 | 
			
		||||
        services.AddScoped<ILectureHallDbContext>(provider => provider.GetService<LectureHallDbContext>()!);
 | 
			
		||||
        services.AddScoped<ILessonAssociationDbContext>(provider => provider.GetService<LessonAssociationDbContext>()!);
 | 
			
		||||
        services.AddScoped<IProfessorDbContext>(provider => provider.GetService<ProfessorDbContext>()!);
 | 
			
		||||
        services.AddScoped<ILessonDbContext>(provider => provider.GetService<LessonDbContext>()!);
 | 
			
		||||
        services.AddScoped<ITypeOfOccupationDbContext>(provider => provider.GetService<TypeOfOccupationDbContext>()!);
 | 
			
		||||
 | 
			
		||||
        return services;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -13,8 +13,9 @@
 | 
			
		||||
	</PropertyGroup>
 | 
			
		||||
 | 
			
		||||
	<ItemGroup>
 | 
			
		||||
		<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" Version="8.0.0" />
 | 
			
		||||
		<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="8.0.0" />
 | 
			
		||||
		<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" Version="8.0.1" />
 | 
			
		||||
		<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="8.0.1" />
 | 
			
		||||
		<PackageReference Include="Microsoft.Extensions.Configuration.Binder" Version="8.0.1" />
 | 
			
		||||
		<PackageReference Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="8.0.0" />
 | 
			
		||||
		<PackageReference Include="Pomelo.EntityFrameworkCore.MySql" Version="8.0.0-beta.2" />
 | 
			
		||||
	</ItemGroup>
 | 
			
		||||
@@ -24,4 +25,8 @@
 | 
			
		||||
		<ProjectReference Include="..\Domain\Domain.csproj" />
 | 
			
		||||
	</ItemGroup>
 | 
			
		||||
 | 
			
		||||
	<ItemGroup>
 | 
			
		||||
		<Folder Include="Migration\" />
 | 
			
		||||
	</ItemGroup>
 | 
			
		||||
 | 
			
		||||
</Project>
 | 
			
		||||
							
								
								
									
										15
									
								
								Persistence/Properties/DbSettings.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								Persistence/Properties/DbSettings.cs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,15 @@
 | 
			
		||||
namespace Mirea.Api.DataAccess.Persistence.Properties;
 | 
			
		||||
 | 
			
		||||
public enum DatabaseEnum
 | 
			
		||||
{
 | 
			
		||||
    Mysql,
 | 
			
		||||
    Sqlite,
 | 
			
		||||
    PostgresSql
 | 
			
		||||
}
 | 
			
		||||
public class DbSettings
 | 
			
		||||
{
 | 
			
		||||
    public bool IsDoneConfiguration { get; set; }
 | 
			
		||||
    public DatabaseEnum TypeDatabase { get; set; }
 | 
			
		||||
    public required string ConnectionStringSql { get; set; }
 | 
			
		||||
    public DatabaseEnum? MigrateTo { get; set; }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user