Added suuport to inject an IOqtaneDatabase in EntityBuilders to allow each Database to control certain Migration behaviors. Also updated Installer to dynamically build Database Configuration section
This commit is contained in:
		| @ -87,7 +87,7 @@ namespace Oqtane.Client | ||||
|                 } | ||||
|  | ||||
|                 // dynamically register database providers | ||||
|                 var databaseTypes = assembly.GetInterfaces<IDatabase>(); | ||||
|                 var databaseTypes = assembly.GetInterfaces<IOqtaneDatabase>(); | ||||
|                 foreach (var databaseType in databaseTypes) | ||||
|                 { | ||||
|                     if (databaseType.AssemblyQualifiedName != null) | ||||
|  | ||||
| @ -1,4 +1,5 @@ | ||||
| @using Oqtane.Interfaces | ||||
| @using System.Reflection | ||||
| @namespace Oqtane.UI | ||||
| @inject NavigationManager NavigationManager | ||||
| @inject IInstallationService InstallationService | ||||
| @ -6,7 +7,7 @@ | ||||
| @inject IUserService UserService | ||||
| @inject IJSRuntime JSRuntime | ||||
| @inject IStringLocalizer<Installer> Localizer | ||||
| @inject IEnumerable<IDatabase> Databases | ||||
| @inject IEnumerable<IOqtaneDatabase> Databases | ||||
|  | ||||
| <div class="container"> | ||||
|     <div class="row"> | ||||
| @ -36,57 +37,50 @@ | ||||
|                             </select> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr style="@(_databaseType == "Sqlite" ? "" : "display: none")"> | ||||
|                         <td> | ||||
|                             <label class="control-label" style="font-weight: bold">@Localizer["File Name:"] </label> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <input type="text" class="form-control" @bind="@_fileName" /> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr style="@(_databaseType == "Sqlite" ? "display: none" : "")"> | ||||
|                         <td> | ||||
|                             <label class="control-label" style="font-weight: bold">@Localizer["Server:"] </label> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <input type="text" class="form-control" @bind="@_serverName" /> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr style="@(_databaseType == "Sqlite" ? "display: none" : "")"> | ||||
|                         <td> | ||||
|                             <label class="control-label" style="font-weight: bold">@Localizer["Database:"] </label> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <input type="text" class="form-control" @bind="@_databaseName" /> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr style="@(_databaseType == "Sqlite" ? "display: none" : "")"> | ||||
|                         <td> | ||||
|                             <label class="control-label" style="font-weight: bold">@Localizer["Integrated Security:"] </label> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <select class="custom-select" @onchange="SetIntegratedSecurity"> | ||||
|                                 <option value="true" selected>@Localizer["True"]</option> | ||||
|                                 <option value="false">@Localizer["False"]</option> | ||||
|                             </select> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr style="@_integratedSecurityDisplay"> | ||||
|                         <td> | ||||
|                             <label class="control-label" style="font-weight: bold">@Localizer["Username:"] </label> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <input type="text" class="form-control" @bind="@_username" /> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr style="@_integratedSecurityDisplay"> | ||||
|                         <td> | ||||
|                             <label class="control-label" style="font-weight: bold">@Localizer["Password:"] </label> | ||||
|                         </td> | ||||
|                         <td> | ||||
|                             <input type="password" class="form-control" @bind="@_password" /> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                 @{ | ||||
|                     _selectedDatabase = Databases.Single(d => d.Name == _databaseType); | ||||
|                     foreach (var field in _selectedDatabase.ConnectionStringFields) | ||||
|                     { | ||||
|                         if (field.Name != "IntegratedSecurity") | ||||
|                         { | ||||
|                             var isVisible = ""; | ||||
|                             var fieldType = (field.Name == "Pwd") ? "password" : "text"; | ||||
|                             if ((field.Name == "Uid" || field.Name == "Pwd") && _selectedDatabase.Name != "MySQL" ) | ||||
|                             { | ||||
|                                 var intSecurityField = _selectedDatabase.ConnectionStringFields.Single(f => f.Name == "IntegratedSecurity"); | ||||
|                                 if (intSecurityField != null) | ||||
|                                 { | ||||
|                                     isVisible = (Convert.ToBoolean(intSecurityField.Value)) ? "display: none;" : ""; | ||||
|                                 } | ||||
|                             } | ||||
|  | ||||
|                             field.Value = field.Value.Replace("{{Date}}", DateTime.UtcNow.ToString("yyyyMMddHHmm")); | ||||
|                              | ||||
|                             <tr style="@isVisible"> | ||||
|                                 <td> | ||||
|                                     <label class="control-label" style="font-weight: bold">@Localizer[$"{field.FriendlyName}:"]</label> | ||||
|                                 </td> | ||||
|                                 <td> | ||||
|                                     <input type="@fieldType" class="form-control" @bind="@field.Value" /> | ||||
|                                 </td> | ||||
|                             </tr> | ||||
|                         } | ||||
|                         else | ||||
|                         { | ||||
|                             <tr> | ||||
|                                 <td> | ||||
|                                     <label class="control-label" style="font-weight: bold">@Localizer[$"{field.FriendlyName}:"]</label> | ||||
|                                 </td> | ||||
|                                 <td> | ||||
|                                     <select class="custom-select" @bind="@field.Value"> | ||||
|                                         <option value="true" selected>@Localizer["True"]</option> | ||||
|                                         <option value="false">@Localizer["False"]</option> | ||||
|                                     </select> | ||||
|                                 </td> | ||||
|                             </tr> | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 </tbody> | ||||
|             </table> | ||||
|         </div> | ||||
| @ -141,18 +135,13 @@ | ||||
| </div> | ||||
|  | ||||
| @code { | ||||
|     private IOqtaneDatabase _selectedDatabase; | ||||
|     private string _databaseType = "LocalDB"; | ||||
|     private string _serverName = "(LocalDb)\\MSSQLLocalDB"; | ||||
|     private string _fileName = "Oqtane-" + DateTime.UtcNow.ToString("yyyyMMddHHmm") + ".db"; | ||||
|     private string _databaseName = "Oqtane-" + DateTime.UtcNow.ToString("yyyyMMddHHmm"); | ||||
|     private string _username = string.Empty; | ||||
|     private string _password = string.Empty; | ||||
|     private string _hostUsername = UserNames.Host; | ||||
|     private string _hostPassword = string.Empty; | ||||
|     private string _confirmPassword = string.Empty; | ||||
|     private string _hostEmail = string.Empty; | ||||
|     private string _message = string.Empty; | ||||
|     private string _integratedSecurityDisplay = "display: none;"; | ||||
|     private string _loadingDisplay = "display: none;"; | ||||
|  | ||||
|     protected override async Task OnAfterRenderAsync(bool firstRender) | ||||
| @ -164,52 +153,21 @@ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void SetIntegratedSecurity(ChangeEventArgs e) | ||||
|     { | ||||
|         _integratedSecurityDisplay = Convert.ToBoolean((string)e.Value) | ||||
|             ? "display: none;" | ||||
|             : string.Empty; | ||||
|     } | ||||
|  | ||||
|     private async Task Install() | ||||
|     { | ||||
|         if (((_serverName != "" && _databaseName != "") || _fileName !="") && _hostUsername != "" && _hostPassword.Length >= 6 && _hostPassword == _confirmPassword && _hostEmail != "") | ||||
|         var connectionString = _selectedDatabase.BuildConnectionString(); | ||||
|  | ||||
|         if (connectionString != "" && _hostUsername != "" && _hostPassword.Length >= 6 && _hostPassword == _confirmPassword && _hostEmail != "") | ||||
|         { | ||||
|             _loadingDisplay = ""; | ||||
|             StateHasChanged(); | ||||
|  | ||||
|             var connectionstring = ""; | ||||
|             var fullyQualifiedType = ""; | ||||
|             switch (_databaseType) | ||||
|             { | ||||
|                 case "LocalDB": | ||||
|                     connectionstring = "Data Source=" + _serverName + ";AttachDbFilename=|DataDirectory|\\" + _databaseName + ".mdf;Initial Catalog=" + _databaseName + ";Integrated Security=SSPI;"; | ||||
|                     fullyQualifiedType = "Oqtane.Repository.Databases.LocalDbDatabase, Oqtane.Server"; | ||||
|                     break; | ||||
|                 case "SQLServer": | ||||
|                     connectionstring = "Data Source=" + _serverName + ";Initial Catalog=" + _databaseName + ";"; | ||||
|                     if (_integratedSecurityDisplay == "display: none;") | ||||
|                     { | ||||
|                         connectionstring += "Integrated Security=SSPI;"; | ||||
|                     } | ||||
|                     else | ||||
|                     { | ||||
|                         connectionstring += "User ID=" + _username + ";Password=" + _password; | ||||
|                     } | ||||
|                     fullyQualifiedType = "Oqtane.Repository.Databases.SqlServerDatabase, Oqtane.Server"; | ||||
|                     break; | ||||
|                 case "Sqlite": | ||||
|                     connectionstring = "Data Source=" + _fileName; | ||||
|                     fullyQualifiedType = "Oqtane.Repository.Databases.SqliteDatabase, Oqtane.Server"; | ||||
|                     break; | ||||
|             } | ||||
|  | ||||
|             Uri uri = new Uri(NavigationManager.Uri); | ||||
|  | ||||
|             var config = new InstallConfig | ||||
|             { | ||||
|                 DatabaseType = fullyQualifiedType, | ||||
|                 ConnectionString = connectionstring, | ||||
|                 DatabaseType = _databaseType, | ||||
|                 ConnectionString = connectionString, | ||||
|                 Aliases = uri.Authority, | ||||
|                 HostEmail = _hostEmail, | ||||
|                 HostPassword = _hostPassword, | ||||
| @ -218,8 +176,6 @@ | ||||
|                 IsNewTenant = true, | ||||
|                 SiteName = Constants.DefaultSite | ||||
|             }; | ||||
|              | ||||
|              | ||||
|  | ||||
|             var installation = await InstallationService.Install(config); | ||||
|             if (installation.Success) | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Charles Nurse
					Charles Nurse