using Microsoft.AspNetCore.Authentication.Cookies; using Microsoft.EntityFrameworkCore; using SoroushAsadi.Data; using SoroushAsadi.Services; var builder = WebApplication.CreateBuilder(args); // --- Razor Pages --- builder.Services.AddRazorPages(); // --- Authentication (single-password cookie auth) --- builder.Services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme) .AddCookie(opt => { opt.LoginPath = "/Admin/Login"; opt.LogoutPath = "/Admin/Logout"; opt.Cookie.Name = "sa_admin"; opt.Cookie.HttpOnly = true; opt.Cookie.SameSite = SameSiteMode.Lax; opt.ExpireTimeSpan = TimeSpan.FromDays(7); opt.SlidingExpiration = true; }); builder.Services.AddAuthorization(); // --- EF Core + SQLite --- var dataDir = builder.Configuration["DataDir"] ?? Path.Combine(builder.Environment.ContentRootPath, "data"); Directory.CreateDirectory(dataDir); Directory.CreateDirectory(Path.Combine(dataDir, "uploads")); builder.Services.AddDbContext(opt => opt.UseSqlite($"Data Source={Path.Combine(dataDir, "cms.db")}")); // --- App services --- builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddHttpClient(); // --- Static file serving for /data/uploads --- builder.Services.Configure(opt => { }); var app = builder.Build(); // Run EF migrations on startup (creates DB if missing) using (var scope = app.Services.CreateScope()) { var db = scope.ServiceProvider.GetRequiredService(); db.Database.EnsureCreated(); } app.UseStatusCodePagesWithReExecute("/Error/{0}"); app.UseStaticFiles(); // Serve uploaded files from /data/uploads under /uploads/* var uploadsPath = Path.Combine(dataDir, "uploads"); app.UseStaticFiles(new StaticFileOptions { FileProvider = new Microsoft.Extensions.FileProviders.PhysicalFileProvider(uploadsPath), RequestPath = "/uploads" }); app.UseRouting(); app.UseAuthentication(); app.UseAuthorization(); app.MapRazorPages(); app.Run();