added system info admin page/module, improved UI for framework, module, and theme install/upgrade, added version to ModuleDefinitions, fixed bug in logging logic introduced during code standardization
This commit is contained in:
parent
62987ca72f
commit
72995cd8fa
|
@ -5,42 +5,47 @@
|
||||||
@inject IModuleDefinitionService ModuleDefinitionService
|
@inject IModuleDefinitionService ModuleDefinitionService
|
||||||
@inject IPackageService PackageService
|
@inject IPackageService PackageService
|
||||||
|
|
||||||
<table class="table table-borderless">
|
|
||||||
<tr>
|
|
||||||
<td>
|
|
||||||
<Label For="module" HelpText="Upload a module from your system">Module: </Label>
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<FileManager Filter="nupkg" ShowFiles="false" Folder="Modules" />
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
@if (_packages != null)
|
@if (_packages != null)
|
||||||
{
|
{
|
||||||
<hr class="app-rule" />
|
<TabStrip>
|
||||||
<div class="mx-auto text-center"><h2>Available Modules</h2></div>
|
@if (_packages.Count > 0)
|
||||||
|
{
|
||||||
|
<TabPanel Name="Download">
|
||||||
|
<ModuleMessage Type="MessageType.Info" Message="Download one or more modules from the list below. Once you are ready click Install to complete the installation."></ModuleMessage>
|
||||||
|
<Pager Items="@_packages">
|
||||||
|
<Header>
|
||||||
|
<th>Name</th>
|
||||||
|
<th>Version</th>
|
||||||
|
<th></th>
|
||||||
|
</Header>
|
||||||
|
<Row>
|
||||||
|
<td>@context.Name</td>
|
||||||
|
<td>@context.Version</td>
|
||||||
|
<td>
|
||||||
|
<button type="button" class="btn btn-primary" @onclick=@(async () => await DownloadModule(context.PackageId, context.Version))>Download</button>
|
||||||
|
</td>
|
||||||
|
</Row>
|
||||||
|
</Pager>
|
||||||
|
</TabPanel>
|
||||||
|
}
|
||||||
|
<TabPanel Name="Upload">
|
||||||
|
<table class="table table-borderless">
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<Label HelpText="Upload one or more module packages. Once they are uploaded click Install to complete the installation.">Module: </Label>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<FileManager Filter="nupkg" ShowFiles="false" Folder="Modules" UploadMultiple="True" />
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</TabPanel>
|
||||||
|
</TabStrip>
|
||||||
|
|
||||||
<Pager Items="@_packages">
|
<button type="button" class="btn btn-success" @onclick="InstallModules">Install</button>
|
||||||
<Header>
|
<NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink>
|
||||||
<th>Name</th>
|
|
||||||
<th>Version</th>
|
|
||||||
<th></th>
|
|
||||||
</Header>
|
|
||||||
<Row>
|
|
||||||
<td>@context.Name</td>
|
|
||||||
<td>@context.Version</td>
|
|
||||||
<td>
|
|
||||||
<button type="button" class="btn btn-primary" @onclick=@(async () => await DownloadModule(context.PackageId, context.Version))>Download Module</button>
|
|
||||||
</td>
|
|
||||||
</Row>
|
|
||||||
</Pager>
|
|
||||||
}
|
}
|
||||||
|
|
||||||
<button type="button" class="btn btn-success" @onclick="InstallModules">Install</button>
|
|
||||||
<NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink>
|
|
||||||
|
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
private List<Package> _packages;
|
private List<Package> _packages;
|
||||||
|
|
||||||
|
@ -52,8 +57,8 @@
|
||||||
{
|
{
|
||||||
var moduledefinitions = await ModuleDefinitionService.GetModuleDefinitionsAsync(PageState.Site.SiteId);
|
var moduledefinitions = await ModuleDefinitionService.GetModuleDefinitionsAsync(PageState.Site.SiteId);
|
||||||
_packages = await PackageService.GetPackagesAsync("module");
|
_packages = await PackageService.GetPackagesAsync("module");
|
||||||
|
|
||||||
foreach(Package package in _packages.ToArray())
|
foreach (Package package in _packages.ToArray())
|
||||||
{
|
{
|
||||||
if (moduledefinitions.Exists(item => Utilities.GetTypeName(item.ModuleDefinitionName) == package.PackageId))
|
if (moduledefinitions.Exists(item => Utilities.GetTypeName(item.ModuleDefinitionName) == package.PackageId))
|
||||||
{
|
{
|
||||||
|
@ -81,18 +86,18 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task DownloadModule(string moduledefinitionname, string version)
|
private async Task DownloadModule(string packageid, string version)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
await PackageService.DownloadPackageAsync(moduledefinitionname, version, "Modules");
|
await PackageService.DownloadPackageAsync(packageid, version, "Modules");
|
||||||
await logger.LogInformation("Module {ModuleDefinitionName} {Version} Downloaded Successfully", moduledefinitionname, version);
|
await logger.LogInformation("Module {ModuleDefinitionName} {Version} Downloaded Successfully", packageid, version);
|
||||||
AddModuleMessage("Module Downloaded Successfully. Click Install To Complete Installation.", MessageType.Success);
|
AddModuleMessage("Modules Downloaded Successfully. Click Install To Complete Installation.", MessageType.Success);
|
||||||
StateHasChanged();
|
StateHasChanged();
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
await logger.LogError(ex, "Error Downloading Module {ModuleDefinitionName} {Version}", moduledefinitionname, version);
|
await logger.LogError(ex, "Error Downloading Module {ModuleDefinitionName} {Version}", packageid, version);
|
||||||
AddModuleMessage("Error Downloading Module", MessageType.Error);
|
AddModuleMessage("Error Downloading Module", MessageType.Error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,29 +1,38 @@
|
||||||
@namespace Oqtane.Modules.Admin.SystemInfo
|
@namespace Oqtane.Modules.Admin.SystemInfo
|
||||||
@inherits ModuleBase
|
@inherits ModuleBase
|
||||||
|
@inject ISystemService SystemService
|
||||||
|
|
||||||
<table class="table table-borderless">
|
<table class="table table-borderless">
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<Label For="version" HelpText="qtane Version">Oqtane Version: </Label>
|
<Label For="version" HelpText="Framework Version">Framework Version: </Label>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
@_version
|
<input id="version" class="form-control" @bind="@_version" disabled />
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<Label For="runtime" HelpText="Blazor Runtime">Blazor Runtime: </Label>
|
<Label For="runtime" HelpText="Blazor Runtime (Server or WebAssembly)">Blazor Runtime: </Label>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
@_runtime
|
<input id="runtime" class="form-control" @bind="@_runtime" disabled />
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<Label For="netcore" HelpText=".NET Core">.NET Core: </Label>
|
<Label For="clrversion" HelpText="Common Language Runtime Version">CLR Version: </Label>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
@_netcore
|
<input id="clrversion" class="form-control" @bind="@_clrversion" disabled />
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<Label For="osversion" HelpText="Operating System Version">OS Version: </Label>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<input id="osversion" class="form-control" @bind="@_osversion" disabled />
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -31,7 +40,7 @@
|
||||||
<Label For="serverpath" HelpText="Server Path">Server Path: </Label>
|
<Label For="serverpath" HelpText="Server Path">Server Path: </Label>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
@_serverpath
|
<input id="serverpath" class="form-control" @bind="@_serverpath" disabled />
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -39,7 +48,7 @@
|
||||||
<Label For="servertime" HelpText="Server Time">Server Time: </Label>
|
<Label For="servertime" HelpText="Server Time">Server Time: </Label>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
@_servertime
|
<input id="servertime" class="form-control" @bind="@_servertime" disabled />
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
@ -49,16 +58,23 @@
|
||||||
|
|
||||||
private string _version = string.Empty;
|
private string _version = string.Empty;
|
||||||
private string _runtime = string.Empty;
|
private string _runtime = string.Empty;
|
||||||
private string _netcore = string.Empty;
|
private string _clrversion = string.Empty;
|
||||||
|
private string _osversion = string.Empty;
|
||||||
private string _serverpath = string.Empty;
|
private string _serverpath = string.Empty;
|
||||||
private string _servertime = string.Empty;
|
private string _servertime = string.Empty;
|
||||||
|
|
||||||
protected override void OnInitialized()
|
protected override async Task OnInitializedAsync()
|
||||||
{
|
{
|
||||||
_version = Constants.Version;
|
_version = Constants.Version;
|
||||||
_runtime = PageState.Runtime.ToString();
|
_runtime = PageState.Runtime.ToString();
|
||||||
_netcore = string.Empty;
|
|
||||||
_serverpath = string.Empty;
|
Dictionary<string, string> systeminfo = await SystemService.GetSystemInfoAsync();
|
||||||
_servertime = string.Empty;
|
if (systeminfo != null)
|
||||||
|
{
|
||||||
|
_clrversion = systeminfo["clrversion"];
|
||||||
|
_osversion = systeminfo["osversion"];
|
||||||
|
_serverpath = systeminfo["serverpath"];
|
||||||
|
_servertime = systeminfo["servertime"];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,70 +5,100 @@
|
||||||
@inject IThemeService ThemeService
|
@inject IThemeService ThemeService
|
||||||
@inject IPackageService PackageService
|
@inject IPackageService PackageService
|
||||||
|
|
||||||
<table class="table table-borderless">
|
@if (_packages != null)
|
||||||
<tr>
|
|
||||||
<td>
|
|
||||||
<Label For="theme" HelpText="Upload a theme from your system">Theme: </Label>
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<FileManager Filter="nupkg" ShowFiles="false" Folder="Themes" />
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
@if (packages != null)
|
|
||||||
{
|
{
|
||||||
<hr class="app-rule" />
|
<TabStrip>
|
||||||
<div class="mx-auto text-center"><h2>Available Themes</h2></div>
|
@if (_packages.Count > 0)
|
||||||
|
{
|
||||||
<Pager Items="@packages">
|
<TabPanel Name="Download">
|
||||||
<Header>
|
<ModuleMessage Type="MessageType.Info" Message="Download one or more themes from the list below. Once you are ready click Install to complete the installation."></ModuleMessage>
|
||||||
<th>Name</th>
|
<Pager Items="@_packages">
|
||||||
<th>Version</th>
|
<Header>
|
||||||
<th></th>
|
<th>Name</th>
|
||||||
</Header>
|
<th>Version</th>
|
||||||
<Row>
|
<th></th>
|
||||||
<td>@context.Name</td>
|
</Header>
|
||||||
<td>@context.Version</td>
|
<Row>
|
||||||
<td>
|
<td>@context.Name</td>
|
||||||
<button type="button" class="btn btn-primary" @onclick=@(async () => await DownloadTheme(context.PackageId, context.Version))>Download Theme</button>
|
<td>@context.Version</td>
|
||||||
</td>
|
<td>
|
||||||
</Row>
|
<button type="button" class="btn btn-primary" @onclick=@(async () => await DownloadTheme(context.PackageId, context.Version))>Download</button>
|
||||||
</Pager>
|
</td>
|
||||||
}
|
</Row>
|
||||||
|
</Pager>
|
||||||
|
</TabPanel>
|
||||||
|
}
|
||||||
|
<TabPanel Name="Upload">
|
||||||
|
<table class="table table-borderless">
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<Label HelpText="Upload one or more theme packages. Once they are uploaded click Install to complete the installation.">Theme: </Label>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<FileManager Filter="nupkg" ShowFiles="false" Folder="Themes" UploadMultiple="True" />
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</TabPanel>
|
||||||
|
</TabStrip>
|
||||||
|
|
||||||
<button type="button" class="btn btn-success" @onclick="InstallThemes">Install</button>
|
<button type="button" class="btn btn-success" @onclick="InstallThemes">Install</button>
|
||||||
<NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink>
|
<NavLink class="btn btn-secondary" href="@NavigateUrl()">Cancel</NavLink>
|
||||||
|
}
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
private List<Package> packages;
|
private List<Package> _packages;
|
||||||
|
|
||||||
public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Host;
|
public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Host;
|
||||||
|
|
||||||
protected override async Task OnInitializedAsync()
|
protected override async Task OnInitializedAsync()
|
||||||
{
|
{
|
||||||
var themes = await ThemeService.GetThemesAsync();
|
try
|
||||||
packages = await PackageService.GetPackagesAsync("theme");
|
|
||||||
|
|
||||||
foreach(Package package in packages.ToArray())
|
|
||||||
{
|
{
|
||||||
if (themes.Exists(item => Utilities.GetTypeName(item.ThemeName) == package.PackageId))
|
var themes = await ThemeService.GetThemesAsync();
|
||||||
|
_packages = await PackageService.GetPackagesAsync("theme");
|
||||||
|
|
||||||
|
foreach (Package package in _packages.ToArray())
|
||||||
{
|
{
|
||||||
packages.Remove(package);
|
if (themes.Exists(item => Utilities.GetTypeName(item.ThemeName) == package.PackageId))
|
||||||
|
{
|
||||||
|
_packages.Remove(package);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
await logger.LogError(ex, "Error Loading Packages {Error}", ex.Message);
|
||||||
|
AddModuleMessage("Error Loading Packages", MessageType.Error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task InstallThemes()
|
private async Task InstallThemes()
|
||||||
{
|
{
|
||||||
await ThemeService.InstallThemesAsync();
|
try
|
||||||
NavigationManager.NavigateTo(NavigateUrl());
|
{
|
||||||
|
await ThemeService.InstallThemesAsync();
|
||||||
|
NavigationManager.NavigateTo(NavigateUrl());
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
await logger.LogError(ex, "Error Installating Theme");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task DownloadTheme(string packageid, string version)
|
private async Task DownloadTheme(string packageid, string version)
|
||||||
{
|
{
|
||||||
await PackageService.DownloadPackageAsync(packageid, version, "Themes");
|
try
|
||||||
AddModuleMessage("Theme Downloaded Successfully. Click Install To Complete Installation.", MessageType.Success);
|
{
|
||||||
StateHasChanged();
|
await PackageService.DownloadPackageAsync(packageid, version, "Themes");
|
||||||
|
await logger.LogInformation("Theme {ThemeName} {Version} Downloaded Successfully", packageid, version);
|
||||||
|
AddModuleMessage("Themes Downloaded Successfully. Click Install To Complete Installation.", MessageType.Success);
|
||||||
|
StateHasChanged();
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
await logger.LogError(ex, "Error Downloading Module {ThemeName} {Version}", packageid, version);
|
||||||
|
AddModuleMessage("Error Downloading Theme", MessageType.Error);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -5,42 +5,55 @@
|
||||||
@inject IPackageService PackageService
|
@inject IPackageService PackageService
|
||||||
@inject IInstallationService InstallationService
|
@inject IInstallationService InstallationService
|
||||||
|
|
||||||
<table class="table table-borderless">
|
@if (_package != null)
|
||||||
<tr>
|
|
||||||
<td>
|
|
||||||
<Label For="framework" HelpText="Upload a framework to update the site">Framework: </Label>
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<FileManager Filter="nupkg" ShowFiles="false" Folder="Framework" />
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
<button type="button" class="btn btn-success" @onclick="Upgrade">Upgrade</button>
|
|
||||||
|
|
||||||
@if (upgradeavailable)
|
|
||||||
{
|
{
|
||||||
<hr class="app-rule" />
|
<TabStrip>
|
||||||
<div class="mx-auto text-center"><h2>Upgrade Available</h2></div>
|
<TabPanel Name="Download">
|
||||||
|
@if (_upgradeavailable)
|
||||||
<button type="button" class="btn btn-success" @onclick=@(async () => await Download(Constants.PackageId, Constants.Version))>Upgrade Framework</button>
|
{
|
||||||
|
<ModuleMessage Type="MessageType.Info" Message="Download a new version of the framework. Once you are ready click Install to complete the installation."></ModuleMessage>
|
||||||
|
@("Framework") @_package.Version <button type="button" class="btn btn-success" @onclick=@(async () => await Download(Constants.PackageId, Constants.Version))>Download</button>
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
<ModuleMessage Type="MessageType.Info" Message="Framework Is Already Up To Date"></ModuleMessage>
|
||||||
|
}
|
||||||
|
</TabPanel>
|
||||||
|
@if (_upgradeavailable)
|
||||||
|
{
|
||||||
|
<TabPanel Name="Upload">
|
||||||
|
<table class="table table-borderless">
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<Label HelpText="Upload a new framework package. Once it is uploaded click Install to complete the installation.">Framework: </Label>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<FileManager Filter="nupkg" ShowFiles="false" Folder="Framework" />
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</TabPanel>
|
||||||
|
}
|
||||||
|
</TabStrip>
|
||||||
}
|
}
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
private bool upgradeavailable = false;
|
private Package _package;
|
||||||
|
private bool _upgradeavailable = false;
|
||||||
|
|
||||||
public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Host;
|
public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Host;
|
||||||
|
|
||||||
protected override async Task OnInitializedAsync()
|
protected override async Task OnInitializedAsync()
|
||||||
{
|
{
|
||||||
var packages = await PackageService.GetPackagesAsync("framework");
|
List<Package> packages = await PackageService.GetPackagesAsync("framework");
|
||||||
var package = packages.FirstOrDefault();
|
_package = packages.FirstOrDefault();
|
||||||
if (package != null)
|
if (_package != null)
|
||||||
{
|
{
|
||||||
upgradeavailable = (Version.Parse(package.Version).CompareTo(Version.Parse(Constants.Version)) > 0);
|
_upgradeavailable = (Version.Parse(_package.Version).CompareTo(Version.Parse(Constants.Version)) > 0);
|
||||||
}
|
}
|
||||||
if (!upgradeavailable)
|
else
|
||||||
{
|
{
|
||||||
AddModuleMessage("Framework Is Up To Date", MessageType.Info);
|
_package = new Package { Name = Constants.PackageId, Version = Constants.Version };
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,6 +52,7 @@ namespace Oqtane.Client
|
||||||
builder.Services.AddScoped<IFileService, FileService>();
|
builder.Services.AddScoped<IFileService, FileService>();
|
||||||
builder.Services.AddScoped<ISiteTemplateService, SiteTemplateService>();
|
builder.Services.AddScoped<ISiteTemplateService, SiteTemplateService>();
|
||||||
builder.Services.AddScoped<ISqlService, SqlService>();
|
builder.Services.AddScoped<ISqlService, SqlService>();
|
||||||
|
builder.Services.AddScoped<ISystemService, SystemService>();
|
||||||
|
|
||||||
// dynamically register module contexts and repository services
|
// dynamically register module contexts and repository services
|
||||||
Assembly[] assemblies = AppDomain.CurrentDomain.GetAssemblies();
|
Assembly[] assemblies = AppDomain.CurrentDomain.GetAssemblies();
|
||||||
|
|
10
Oqtane.Client/Services/Interfaces/ISystemService.cs
Normal file
10
Oqtane.Client/Services/Interfaces/ISystemService.cs
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace Oqtane.Services
|
||||||
|
{
|
||||||
|
public interface ISystemService
|
||||||
|
{
|
||||||
|
Task<Dictionary<string, string>> GetSystemInfoAsync();
|
||||||
|
}
|
||||||
|
}
|
32
Oqtane.Client/Services/SystemService.cs
Normal file
32
Oqtane.Client/Services/SystemService.cs
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
using System.Net.Http;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Microsoft.AspNetCore.Components;
|
||||||
|
using Oqtane.Shared;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace Oqtane.Services
|
||||||
|
{
|
||||||
|
public class SystemService : ServiceBase, ISystemService
|
||||||
|
{
|
||||||
|
|
||||||
|
private readonly SiteState _siteState;
|
||||||
|
private readonly NavigationManager _navigationManager;
|
||||||
|
|
||||||
|
public SystemService(HttpClient http, SiteState siteState, NavigationManager navigationManager) : base(http)
|
||||||
|
{
|
||||||
|
|
||||||
|
_siteState = siteState;
|
||||||
|
_navigationManager = navigationManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
private string Apiurl
|
||||||
|
{
|
||||||
|
get { return CreateApiUrl(_siteState.Alias, _navigationManager.Uri, "System"); }
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<Dictionary<string, string>> GetSystemInfoAsync()
|
||||||
|
{
|
||||||
|
return await GetJsonAsync<Dictionary<string, string>>(Apiurl);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
35
Oqtane.Server/Controllers/SystemController.cs
Normal file
35
Oqtane.Server/Controllers/SystemController.cs
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using Microsoft.AspNetCore.Authorization;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using Oqtane.Shared;
|
||||||
|
using System;
|
||||||
|
using Microsoft.AspNetCore.Hosting;
|
||||||
|
|
||||||
|
namespace Oqtane.Controllers
|
||||||
|
{
|
||||||
|
[Route("{site}/api/[controller]")]
|
||||||
|
public class SystemController : Controller
|
||||||
|
{
|
||||||
|
private readonly IWebHostEnvironment _environment;
|
||||||
|
|
||||||
|
public SystemController(IWebHostEnvironment environment)
|
||||||
|
{
|
||||||
|
_environment = environment;
|
||||||
|
}
|
||||||
|
|
||||||
|
// GET: api/<controller>
|
||||||
|
[HttpGet]
|
||||||
|
[Authorize(Roles = Constants.HostRole)]
|
||||||
|
public Dictionary<string, string> Get()
|
||||||
|
{
|
||||||
|
Dictionary<string, string> systeminfo = new Dictionary<string, string>();
|
||||||
|
systeminfo.Add("clrversion", Environment.Version.ToString());
|
||||||
|
systeminfo.Add("osversion", Environment.OSVersion.ToString());
|
||||||
|
systeminfo.Add("machinename", Environment.MachineName);
|
||||||
|
systeminfo.Add("serverpath", _environment.ContentRootPath);
|
||||||
|
systeminfo.Add("servertime", DateTime.Now.ToString());
|
||||||
|
return systeminfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -75,7 +75,7 @@ namespace Oqtane.Infrastructure
|
||||||
log.Url = $"{request.Scheme}://{request.Host}{request.Path}{request.QueryString}";
|
log.Url = $"{request.Scheme}://{request.Host}{request.Path}{request.QueryString}";
|
||||||
}
|
}
|
||||||
|
|
||||||
Type type = @class.GetType();
|
Type type = Type.GetType(@class.ToString());
|
||||||
if (type != null)
|
if (type != null)
|
||||||
{
|
{
|
||||||
log.Category = type.AssemblyQualifiedName;
|
log.Category = type.AssemblyQualifiedName;
|
||||||
|
|
|
@ -105,6 +105,10 @@ namespace Oqtane.Repository
|
||||||
{
|
{
|
||||||
moduledefinition.Categories = moduledef.Categories;
|
moduledefinition.Categories = moduledef.Categories;
|
||||||
}
|
}
|
||||||
|
if (!string.IsNullOrEmpty(moduledef.Version))
|
||||||
|
{
|
||||||
|
moduledefinition.Version = moduledef.Version;
|
||||||
|
}
|
||||||
if (permissions.Count == 0)
|
if (permissions.Count == 0)
|
||||||
{
|
{
|
||||||
_permissions.UpdatePermissions(siteId, EntityNames.ModuleDefinition, moduledef.ModuleDefinitionId, moduledefinition.Permissions);
|
_permissions.UpdatePermissions(siteId, EntityNames.ModuleDefinition, moduledef.ModuleDefinitionId, moduledefinition.Permissions);
|
||||||
|
@ -173,23 +177,29 @@ namespace Oqtane.Repository
|
||||||
.FirstOrDefault(item => item.GetInterfaces().Contains(typeof(IModule)));
|
.FirstOrDefault(item => item.GetInterfaces().Contains(typeof(IModule)));
|
||||||
if (moduletype != null)
|
if (moduletype != null)
|
||||||
{
|
{
|
||||||
|
// get property values from IModule
|
||||||
var moduleobject = Activator.CreateInstance(moduletype);
|
var moduleobject = Activator.CreateInstance(moduletype);
|
||||||
moduledefinition = (ModuleDefinition)moduletype.GetProperty("ModuleDefinition").GetValue(moduleobject);
|
moduledefinition = (ModuleDefinition)moduletype.GetProperty("ModuleDefinition").GetValue(moduleobject);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// set default property values
|
||||||
moduledefinition = new ModuleDefinition
|
moduledefinition = new ModuleDefinition
|
||||||
{
|
{
|
||||||
Name = moduleType.Substring(moduleType.LastIndexOf(".") + 1),
|
Name = moduleType.Substring(moduleType.LastIndexOf(".") + 1),
|
||||||
Description = "Manage " + moduleType.Substring(moduleType.LastIndexOf(".") + 1),
|
Description = "Manage " + moduleType.Substring(moduleType.LastIndexOf(".") + 1),
|
||||||
Categories = ((qualifiedModuleType.StartsWith("Oqtane.Modules.Admin.")) ? "Admin" : ""),
|
Categories = ((qualifiedModuleType.StartsWith("Oqtane.Modules.Admin.")) ? "Admin" : ""),
|
||||||
Version = new Version(1, 0, 0).ToString()
|
Version = "1.0.0"
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
// set internal properties
|
// set internal properties
|
||||||
moduledefinition.ModuleDefinitionName = qualifiedModuleType;
|
moduledefinition.ModuleDefinitionName = qualifiedModuleType;
|
||||||
moduledefinition.ControlTypeTemplate = moduleType + "." + Constants.ActionToken + ", " + typename[1];
|
moduledefinition.ControlTypeTemplate = moduleType + "." + Constants.ActionToken + ", " + typename[1];
|
||||||
moduledefinition.AssemblyName = assembly.FullName.Split(",")[0];
|
moduledefinition.AssemblyName = assembly.FullName.Split(",")[0];
|
||||||
|
if (assembly.FullName.StartsWith("Oqtane.Client"))
|
||||||
|
{
|
||||||
|
moduledefinition.Version = Constants.Version;
|
||||||
|
}
|
||||||
if (string.IsNullOrEmpty(moduledefinition.Categories))
|
if (string.IsNullOrEmpty(moduledefinition.Categories))
|
||||||
{
|
{
|
||||||
moduledefinition.Categories = "Common";
|
moduledefinition.Categories = "Common";
|
||||||
|
|
|
@ -388,6 +388,34 @@ namespace Oqtane.Repository
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
pageTemplates.Add(new PageTemplate
|
pageTemplates.Add(new PageTemplate
|
||||||
|
{
|
||||||
|
Name = "System Info",
|
||||||
|
Parent = "Admin",
|
||||||
|
Path = "admin/system",
|
||||||
|
Icon = "medical-cross",
|
||||||
|
IsNavigation = false,
|
||||||
|
IsPersonalizable = false,
|
||||||
|
EditMode = true,
|
||||||
|
PagePermissions = new List<Permission>
|
||||||
|
{
|
||||||
|
new Permission(PermissionNames.View, Constants.AdminRole, true),
|
||||||
|
new Permission(PermissionNames.Edit, Constants.AdminRole, true)
|
||||||
|
}.EncodePermissions(),
|
||||||
|
PageTemplateModules = new List<PageTemplateModule>
|
||||||
|
{
|
||||||
|
new PageTemplateModule
|
||||||
|
{
|
||||||
|
ModuleDefinitionName = typeof(Oqtane.Modules.Admin.SystemInfo.Index).ToModuleDefinitionName(), Title = "System Info", Pane = "Content",
|
||||||
|
ModulePermissions = new List<Permission>
|
||||||
|
{
|
||||||
|
new Permission(PermissionNames.View, Constants.AdminRole, true),
|
||||||
|
new Permission(PermissionNames.Edit, Constants.AdminRole, true)
|
||||||
|
}.EncodePermissions(),
|
||||||
|
Content = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
pageTemplates.Add(new PageTemplate
|
||||||
{
|
{
|
||||||
Name = "Upgrade Service", Parent = "Admin", Path = "admin/upgrade", Icon = Icons.Aperture, IsNavigation = false, IsPersonalizable = false, EditMode = true,
|
Name = "Upgrade Service", Parent = "Admin", Path = "admin/upgrade", Icon = Icons.Aperture, IsNavigation = false, IsPersonalizable = false, EditMode = true,
|
||||||
PagePermissions = new List<Permission>
|
PagePermissions = new List<Permission>
|
||||||
|
|
|
@ -43,6 +43,7 @@ CREATE TABLE [dbo].[ModuleDefinition](
|
||||||
[Name] [nvarchar](200) NULL,
|
[Name] [nvarchar](200) NULL,
|
||||||
[Description] [nvarchar](2000) NULL,
|
[Description] [nvarchar](2000) NULL,
|
||||||
[Categories] [nvarchar](200) NULL,
|
[Categories] [nvarchar](200) NULL,
|
||||||
|
[Version] [nvarchar](50) NULL,
|
||||||
[CreatedBy] [nvarchar](256) NOT NULL,
|
[CreatedBy] [nvarchar](256) NOT NULL,
|
||||||
[CreatedOn] [datetime] NOT NULL,
|
[CreatedOn] [datetime] NOT NULL,
|
||||||
[ModifiedBy] [nvarchar](256) NOT NULL,
|
[ModifiedBy] [nvarchar](256) NOT NULL,
|
||||||
|
|
|
@ -102,6 +102,7 @@ namespace Oqtane
|
||||||
services.AddScoped<IFileService, FileService>();
|
services.AddScoped<IFileService, FileService>();
|
||||||
services.AddScoped<ISiteTemplateService, SiteTemplateService>();
|
services.AddScoped<ISiteTemplateService, SiteTemplateService>();
|
||||||
services.AddScoped<ISqlService, SqlService>();
|
services.AddScoped<ISqlService, SqlService>();
|
||||||
|
services.AddScoped<ISystemService, SystemService>();
|
||||||
|
|
||||||
services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();
|
services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@ namespace Oqtane.Models
|
||||||
public string Name { get; set; }
|
public string Name { get; set; }
|
||||||
public string Description { get; set; }
|
public string Description { get; set; }
|
||||||
public string Categories { get; set; }
|
public string Categories { get; set; }
|
||||||
|
public string Version { get; set; }
|
||||||
|
|
||||||
public string CreatedBy { get; set; }
|
public string CreatedBy { get; set; }
|
||||||
public DateTime CreatedOn { get; set; }
|
public DateTime CreatedOn { get; set; }
|
||||||
|
@ -36,8 +37,6 @@ namespace Oqtane.Models
|
||||||
[NotMapped]
|
[NotMapped]
|
||||||
public int SiteId { get; set; }
|
public int SiteId { get; set; }
|
||||||
[NotMapped]
|
[NotMapped]
|
||||||
public string Version { get; set; }
|
|
||||||
[NotMapped]
|
|
||||||
public string Owner { get; set; }
|
public string Owner { get; set; }
|
||||||
[NotMapped]
|
[NotMapped]
|
||||||
public string Url { get; set; }
|
public string Url { get; set; }
|
||||||
|
|
Loading…
Reference in New Issue
Block a user