
done: + master.sql as resource + implemented incremental database changes also for Master + dbUp sql script variables implemented + improved database handling and creation code + simpified database creation + almost all Database and Tenant creation moved to DatabaseManager.cs (rest code marked with TODO) + Unattended install of master can be performed by settings in appsettings.json + Improved IsInstalled checking + Removed DBSchema field from Tenant + Default database and site creation moved to Program.Main
77 lines
2.3 KiB
Plaintext
77 lines
2.3 KiB
Plaintext
@namespace Oqtane.Modules.Admin.Tenants
|
|
@inherits ModuleBase
|
|
@inject NavigationManager NavigationManager
|
|
@inject ITenantService TenantService
|
|
|
|
<table class="table table-borderless">
|
|
<tr>
|
|
<td>
|
|
<label class="control-label">Name: </label>
|
|
</td>
|
|
<td>
|
|
<input class="form-control" @bind="@name" />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<label class="control-label">Connection String: </label>
|
|
</td>
|
|
<td>
|
|
<input class="form-control" @bind="@connectionstring" />
|
|
</td>
|
|
</tr>
|
|
|
|
</table>
|
|
<button type="button" class="btn btn-success" @onclick="SaveTenant">Save</button>
|
|
<NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink>
|
|
|
|
@code {
|
|
public override SecurityAccessLevel SecurityAccessLevel { get { return SecurityAccessLevel.Host; } }
|
|
|
|
int tenantid;
|
|
string name = "";
|
|
string connectionstring = "";
|
|
|
|
protected override async Task OnInitializedAsync()
|
|
{
|
|
try
|
|
{
|
|
tenantid = Int32.Parse(PageState.QueryString["id"]);
|
|
Tenant tenant = await TenantService.GetTenantAsync(tenantid);
|
|
if (tenant != null)
|
|
{
|
|
name = tenant.Name;
|
|
connectionstring = tenant.DBConnectionString;
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
await logger.LogError(ex, "Error Loading Tenant {TenantId} {Error}", tenantid, ex.Message);
|
|
AddModuleMessage("Error Loading Tenant", MessageType.Error);
|
|
}
|
|
}
|
|
|
|
private async Task SaveTenant()
|
|
{
|
|
try
|
|
{
|
|
connectionstring = connectionstring.Replace("\\\\", "\\");
|
|
Tenant tenant = await TenantService.GetTenantAsync(tenantid);
|
|
if (tenant != null)
|
|
{
|
|
tenant.Name = name;
|
|
tenant.DBConnectionString = connectionstring;
|
|
await TenantService.UpdateTenantAsync(tenant);
|
|
await logger.LogInformation("Tenant Saved {TenantId}", tenantid);
|
|
|
|
NavigationManager.NavigateTo(NavigateUrl());
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
await logger.LogError(ex, "Error Saving Tenant {TenantId} {Error}", tenantid, ex.Message);
|
|
AddModuleMessage("Error Saving Tenant", MessageType.Error);
|
|
}
|
|
}
|
|
}
|