using EntityFrameworkCore.Data; using Microsoft.EntityFrameworkCore; var builder = WebApplication.CreateBuilder(args); // Add services to the container. // Learn more about configuring OpenAPI at https://aka.ms/aspnet/openapi builder.Services.AddOpenApi(); var sqliteDatabaseName = builder.Configuration.GetConnectionString("SqliteDatabaseName"); var folder = Environment.SpecialFolder.LocalApplicationData; var path = Environment.GetFolderPath(folder); var dbPath = Path.Combine(path, sqliteDatabaseName); var connectionString = $"Data Source={dbPath}"; builder.Services.AddDbContext(options => { options.UseSqlite(connectionString) .UseQueryTrackingBehavior(QueryTrackingBehavior.NoTracking) .LogTo(Console.WriteLine, LogLevel.Information); if (!builder.Environment.IsProduction()) { // Do not allow this in Production. options.EnableSensitiveDataLogging(); options.EnableDetailedErrors(); } }); var app = builder.Build(); // Configure the HTTP request pipeline. if (app.Environment.IsDevelopment()) { app.MapOpenApi(); } app.UseHttpsRedirection(); var summaries = new[] { "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching" }; app.MapGet("/weatherforecast", () => { var forecast = Enumerable.Range(1, 5).Select(index => new WeatherForecast ( DateOnly.FromDateTime(DateTime.Now.AddDays(index)), Random.Shared.Next(-20, 55), summaries[Random.Shared.Next(summaries.Length)] )) .ToArray(); return forecast; }) .WithName("GetWeatherForecast"); app.Run(); record WeatherForecast(DateOnly Date, int TemperatureC, string? Summary) { public int TemperatureF => 32 + (int)(TemperatureC / 0.5556); }