diff --git a/Oqtane.Client/App.razor b/Oqtane.Client/App.razor
index 3d13adff8..ca4b25bd4 100644
--- a/Oqtane.Client/App.razor
+++ b/Oqtane.Client/App.razor
@@ -1,31 +1,39 @@
-@inject IInstallationService InstallationService
+@inject IInstallationService InstallationService
@if (_initialized)
{
- @if (!_installed)
+ @if (!_installation.Success)
{
}
else
{
-
-
-
-
-
+ @if (string.IsNullOrEmpty(_installation.Message))
+ {
+
+
+
+
+
+ }
+ else
+ {
+
+ @_installation.Message
+
+ }
}
}
@code {
+ private Installation _installation;
private bool _initialized;
- private bool _installed;
private PageState PageState { get; set; }
protected override async Task OnParametersSetAsync()
{
- var installation = await InstallationService.IsInstalled();
- _installed = installation.Success;
+ _installation = await InstallationService.IsInstalled();
_initialized = true;
}
diff --git a/Oqtane.Client/Modules/Admin/Sites/Index.razor b/Oqtane.Client/Modules/Admin/Sites/Index.razor
index 3a571cd39..9d028e1dd 100644
--- a/Oqtane.Client/Modules/Admin/Sites/Index.razor
+++ b/Oqtane.Client/Modules/Admin/Sites/Index.razor
@@ -22,7 +22,7 @@ else
|
|
- @context.Name |
+ @context.Name |
}
diff --git a/Oqtane.Server/Controllers/InstallationController.cs b/Oqtane.Server/Controllers/InstallationController.cs
index 01de103b7..2d8491d66 100644
--- a/Oqtane.Server/Controllers/InstallationController.cs
+++ b/Oqtane.Server/Controllers/InstallationController.cs
@@ -55,8 +55,7 @@ public Installation Post([FromBody] InstallConfig config)
[HttpGet("installed")]
public Installation IsInstalled()
{
- bool isInstalled = _databaseManager.IsInstalled();
- return new Installation {Success = isInstalled, Message = string.Empty};
+ return _databaseManager.IsInstalled();
}
[HttpGet("upgrade")]
diff --git a/Oqtane.Server/Infrastructure/DatabaseManager.cs b/Oqtane.Server/Infrastructure/DatabaseManager.cs
index 308b5cf0f..9ee98e257 100644
--- a/Oqtane.Server/Infrastructure/DatabaseManager.cs
+++ b/Oqtane.Server/Infrastructure/DatabaseManager.cs
@@ -33,27 +33,30 @@ public DatabaseManager(IConfigurationRoot config, IServiceScopeFactory serviceSc
_cache = cache;
}
- public bool IsInstalled()
+ public Installation IsInstalled()
{
- var defaultConnectionString = NormalizeConnectionString(_config.GetConnectionString(SettingKeys.ConnectionStringKey));
- var result = !string.IsNullOrEmpty(defaultConnectionString);
- if (result)
+ var result = new Installation { Success = false, Message = string.Empty };
+ if (!string.IsNullOrEmpty(_config.GetConnectionString(SettingKeys.ConnectionStringKey)))
{
+ result.Success = true;
using (var scope = _serviceScopeFactory.CreateScope())
{
var db = scope.ServiceProvider.GetRequiredService();
- result = db.Database.CanConnect();
- if (result)
+ if (db.Database.CanConnect())
{
try
{
- result = db.Tenant.Any();
+ var provisioned = db.Tenant.Any();
}
catch
{
- result = false;
+ result.Message = "Master Database Not Installed Correctly";
}
}
+ else
+ {
+ result.Message = "Cannot Connect To Master Database";
+ }
}
}
return result;
@@ -74,7 +77,8 @@ public Installation Install(InstallConfig install)
// startup or silent installation
install = new InstallConfig { ConnectionString = _config.GetConnectionString(SettingKeys.ConnectionStringKey), TenantName = TenantNames.Master, IsNewTenant = false };
- if (!IsInstalled())
+ var installation = IsInstalled();
+ if (!installation.Success)
{
install.Aliases = GetInstallationConfig(SettingKeys.DefaultAliasKey, string.Empty);
install.HostPassword = GetInstallationConfig(SettingKeys.HostPasswordKey, string.Empty);
@@ -97,6 +101,14 @@ public Installation Install(InstallConfig install)
install.ConnectionString = "";
}
}
+ else
+ {
+ if (!string.IsNullOrEmpty(installation.Message))
+ {
+ // problem with prior installation
+ install.ConnectionString = "";
+ }
+ }
}
else
{
diff --git a/Oqtane.Server/Infrastructure/Interfaces/IDatabaseManager.cs b/Oqtane.Server/Infrastructure/Interfaces/IDatabaseManager.cs
index ffb0ff9cc..6257db16b 100644
--- a/Oqtane.Server/Infrastructure/Interfaces/IDatabaseManager.cs
+++ b/Oqtane.Server/Infrastructure/Interfaces/IDatabaseManager.cs
@@ -1,11 +1,11 @@
-using Oqtane.Models;
+using Oqtane.Models;
using Oqtane.Shared;
namespace Oqtane.Infrastructure
{
public interface IDatabaseManager
{
- bool IsInstalled();
+ Installation IsInstalled();
Installation Install();
Installation Install(InstallConfig install);
}
diff --git a/Oqtane.Server/Infrastructure/UpgradeManager.cs b/Oqtane.Server/Infrastructure/UpgradeManager.cs
index cbfcc63b9..b2385b2b5 100644
--- a/Oqtane.Server/Infrastructure/UpgradeManager.cs
+++ b/Oqtane.Server/Infrastructure/UpgradeManager.cs
@@ -25,14 +25,12 @@ public UpgradeManager(IAliasRepository aliases, IServiceScopeFactory serviceScop
public void Upgrade(Tenant tenant, string version)
{
- // core framework upgrade logic - note that you can check if current tenant is Master if you only want to execute logic once
- var pageTemplates = new List();
-
+ // core framework upgrade logic - note that you can check if current tenant is Master if you only want to execute the logic once
switch (version)
{
case "0.9.0":
- // add a page to all existing sites on upgrade
-
+ // this code is commented out on purpose - it provides an example of how to programmatically add a page to all existing sites on upgrade
+ var pageTemplates = new List();
//pageTemplates.Add(new PageTemplate
//{
// Name = "Test",
@@ -68,7 +66,12 @@ public void Upgrade(Tenant tenant, string version)
case "2.0.2":
if (tenant.Name == TenantNames.Master)
{
- Directory.Delete(Utilities.PathCombine(_environment.WebRootPath, "Modules", "Templates", "Internal", Path.DirectorySeparatorChar.ToString()), true);
+ // remove Internal module template files as they are no longer supported
+ var internalTemplatePath = Utilities.PathCombine(_environment.WebRootPath, "Modules", "Templates", "Internal", Path.DirectorySeparatorChar.ToString());
+ if (Directory.Exists(internalTemplatePath))
+ {
+ Directory.Delete(internalTemplatePath, true);
+ }
}
break;
}
diff --git a/Oqtane.Server/Pages/_Host.cshtml b/Oqtane.Server/Pages/_Host.cshtml
index e1cc6c21a..1678969c8 100644
--- a/Oqtane.Server/Pages/_Host.cshtml
+++ b/Oqtane.Server/Pages/_Host.cshtml
@@ -37,7 +37,9 @@
@if (Model.Message != "")
{
- @Model.Message
+
+ @Model.Message
+
}
diff --git a/Oqtane.Server/wwwroot/css/app.css b/Oqtane.Server/wwwroot/css/app.css
index ce87887da..eebf63a6d 100644
--- a/Oqtane.Server/wwwroot/css/app.css
+++ b/Oqtane.Server/wwwroot/css/app.css
@@ -1,4 +1,4 @@
-@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');
+@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');
html, body {
font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
@@ -125,6 +125,13 @@ app {
vertical-align: inherit;
}
+.app-alert {
+ padding: 20px;
+ background-color: #f44336; /* red */
+ color: white;
+ margin-bottom: 15px;
+}
+
/* Tooltips */
.app-tooltip {
cursor: help;