efcf7b180c
Fixes 'error while parsing protocol' HanaException by supporting SSL/TLS encryption, Multi-Tenant Database Container (MDC) database name, and arbitrary additional connection parameters. - HanaServer model: added DatabaseName, UseSsl, ValidateCertificate, AdditionalParams fields + BuildConnectionString() helper - HanaQueryService: accepts HanaServer directly, uses BuildConnectionString() for full parameter support - AppDbContext: added EnsureSchema() method that uses PRAGMA table_info + ALTER TABLE ADD COLUMN to add the new fields to existing SQLite databases without losing data (EnsureCreated does not update schema) - Program.cs: calls EnsureSchema on startup before seeding - Standorte.razor: server dialog now exposes DatabaseName, UseSsl, ValidateCertificate, AdditionalParams with helper texts; test connection uses new signature https://claude.ai/code/session_012heAXNMbbyxqYf2S2HrKLj
46 lines
1.3 KiB
C#
46 lines
1.3 KiB
C#
using Microsoft.EntityFrameworkCore;
|
|
using MudBlazor.Services;
|
|
using TrafagSalesExporter.Data;
|
|
using TrafagSalesExporter.Services;
|
|
|
|
var builder = WebApplication.CreateBuilder(args);
|
|
|
|
builder.Services.AddRazorComponents()
|
|
.AddInteractiveServerComponents();
|
|
|
|
builder.Services.AddMudServices();
|
|
|
|
builder.Services.AddDbContextFactory<AppDbContext>(options =>
|
|
options.UseSqlite("Data Source=trafag_exporter.db"));
|
|
|
|
builder.Services.AddSingleton<HanaQueryService>();
|
|
builder.Services.AddSingleton<ExcelExportService>();
|
|
builder.Services.AddSingleton<SharePointUploadService>();
|
|
builder.Services.AddSingleton<ExportOrchestrationService>();
|
|
builder.Services.AddSingleton<TimerBackgroundService>();
|
|
builder.Services.AddHostedService(sp => sp.GetRequiredService<TimerBackgroundService>());
|
|
|
|
var app = builder.Build();
|
|
|
|
using (var scope = app.Services.CreateScope())
|
|
{
|
|
var dbFactory = scope.ServiceProvider.GetRequiredService<IDbContextFactory<AppDbContext>>();
|
|
using var db = await dbFactory.CreateDbContextAsync();
|
|
await db.Database.EnsureCreatedAsync();
|
|
AppDbContext.EnsureSchema(db);
|
|
AppDbContext.SeedIfEmpty(db);
|
|
}
|
|
|
|
if (!app.Environment.IsDevelopment())
|
|
{
|
|
app.UseHsts();
|
|
}
|
|
|
|
app.UseStaticFiles();
|
|
app.UseAntiforgery();
|
|
|
|
app.MapRazorComponents<TrafagSalesExporter.Components.App>()
|
|
.AddInteractiveServerRenderMode();
|
|
|
|
app.Run();
|