From 069e4a53116f629546f39bfd029d5f400ea24957 Mon Sep 17 00:00:00 2001 From: Sergey Karmanov Date: Thu, 6 Feb 2025 07:20:43 +0300 Subject: [PATCH] =?UTF-8?q?=D0=98=D0=B7=D0=BC=D0=B5=D0=BD=D0=B8=D0=BB=20?= =?UTF-8?q?=D0=BF=D0=B0=D0=BF=D0=BA=D1=83=20=D0=BD=D0=B0=D1=85=D0=BE=D0=B6?= =?UTF-8?q?=D0=B4=D0=B5=D0=BD=D0=B8=D1=8F=20=D0=B1=D0=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/Otchinslator/DatabaseContext.cs | 13 ++++--------- src/Otchinslator/Program.cs | 8 +++++++- 2 files changed, 11 insertions(+), 10 deletions(-) diff --git a/src/Otchinslator/DatabaseContext.cs b/src/Otchinslator/DatabaseContext.cs index 79cb0c6..f5cf753 100644 --- a/src/Otchinslator/DatabaseContext.cs +++ b/src/Otchinslator/DatabaseContext.cs @@ -9,6 +9,10 @@ public class DatabaseContext : DbContext public DbSet Specialties { get; set; } public string DbPath { get; } + public DatabaseContext(DbContextOptions options) : base(options) + { + } + protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity().HasKey(i => i.Id); @@ -37,13 +41,4 @@ public class DatabaseContext : DbContext new Specialty() { Id = 10, Name = "Безопасность информационных технологий в правоохранительной сфере", Code = "10.05.05", InstitutId = 1 } ); } - - public DatabaseContext() - { - var folder = Environment.SpecialFolder.LocalApplicationData; - DbPath = System.IO.Path.Join("./", "database.db"); - } - - protected override void OnConfiguring(DbContextOptionsBuilder options) - => options.UseSqlite($"Data Source={DbPath}"); } \ No newline at end of file diff --git a/src/Otchinslator/Program.cs b/src/Otchinslator/Program.cs index 3fd6a28..211fbf5 100644 --- a/src/Otchinslator/Program.cs +++ b/src/Otchinslator/Program.cs @@ -29,7 +29,13 @@ builder.Services.Configure(options => options.ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto; }); -builder.Services.AddDbContext(); +var baseDirectory = AppDomain.CurrentDomain.BaseDirectory; +var folder = Path.Join(baseDirectory, "Data"); +if (!Directory.Exists(folder)) + Directory.CreateDirectory(folder); + +folder = Path.Join(folder, "database.db"); +builder.Services.AddDbContext(options => options.UseSqlite($"Data Source={folder}")); // Add services to the container. builder.Services.AddRazorComponents()