BootstrapAdmin/Bootstrap.Admin/HealthChecks/DBHealthCheck.cs

71 lines
2.8 KiB
C#
Raw Normal View History

using Bootstrap.DataAccess;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Diagnostics.HealthChecks;
using System;
using System.Collections.Generic;
using System.Linq;
2019-08-13 13:39:18 +08:00
using System.Threading;
using System.Threading.Tasks;
using Task = System.Threading.Tasks.Task;
2019-08-13 13:39:18 +08:00
namespace Bootstrap.Admin.HealthChecks
{
/// <summary>
2019-08-13 14:39:35 +08:00
/// 数据库检查类
2019-08-13 13:39:18 +08:00
/// </summary>
public class DBHealthCheck : IHealthCheck
{
private IConfiguration _configuration;
private static readonly Func<IConfiguration, string, string> ConnectionStringResolve = (c, name) => string.IsNullOrEmpty(name)
? c.GetSection("ConnectionStrings").GetChildren().FirstOrDefault()?.Value
: c.GetConnectionString(name);
/// <summary>
/// 构造函数
/// </summary>
/// <param name="configuration"></param>
public DBHealthCheck(IConfiguration configuration)
{
_configuration = configuration;
}
2019-08-13 13:39:18 +08:00
/// <summary>
/// 异步检查方法
/// </summary>
/// <param name="context"></param>
/// <param name="cancellationToken"></param>
/// <returns></returns>
public Task<HealthCheckResult> CheckHealthAsync(HealthCheckContext context, CancellationToken cancellationToken = default)
{
var db = _configuration.GetSection("DB").GetChildren()
.Select(config => new
{
Enabled = bool.TryParse(config["Enabled"], out var en) ? en : false,
ProviderName = config["ProviderName"],
Widget = config["Widget"],
ConnectionString = ConnectionStringResolve(config.GetSection("ConnectionStrings").Exists() ? config : _configuration, string.Empty)
}).FirstOrDefault(i => i.Enabled);
// 检查 Admin 账户权限
var user = UserHelper.RetrieveUserByUserName("Admin");
var roles = RoleHelper.RetrievesByUserName("Admin");
var dicts = DictHelper.RetrieveDicts();
var menus = MenuHelper.RetrieveMenusByUserName("Admin");
var data = new Dictionary<string, object>()
{
{ "ConnectionString", db.ConnectionString },
{ "Widget", db.Widget },
{ "DbType", db.ProviderName },
{ "Dicts", dicts.Count() },
{ "User(Admin)", user != null },
{ "Roles(Admin)", string.Join(",", roles) },
{ "Navigations(Admin)", menus.Count() }
};
var v = dicts.Any() && user != null && roles.Any() && menus.Any();
return v ? Task.FromResult(HealthCheckResult.Healthy("Ok", data)) : Task.FromResult(HealthCheckResult.Degraded("Failed"));
2019-08-13 13:39:18 +08:00
}
}
}